trayscale
Centrifugo
trayscale | Centrifugo | |
---|---|---|
12 | 31 | |
340 | 7,944 | |
- | 1.6% | |
6.6 | 8.9 | |
7 days ago | 4 days ago | |
Go | Go | |
MIT License | Apache License 2.0 |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
trayscale
-
Does tailscale have a linux application with a GUI?
There's something like this. I try but my internet stop working when I use that. https://github.com/DeedleFake/trayscale
-
As a Go programmer, what design pattern, programming techniques have you actually used, implemented regularly in your workplace which made your life much easier?
I've actually just recently used this with both pointer and value reveivers in one of my own projects.
-
Suggestions for out-of-date dependencies in the GitHub Actions runners?
I've got a project that depends on Libadwaita 1.2. The ubuntu-latest runner is 22.04 which only has Libadwaita 1.1 available in its repos, causing all of my CI runs to fail. I don't use Ubuntu personally so maybe this is something I can fix via APT and I just don't know how, but what's the recommended procedure for handling a situation where the runner's version of a dependency of a project is out-of-date? I couldn't seem to find anything in the official documentation or anywhere else via Google.
- Tailscale Plugin for KDE?
-
Go taking too much time building with imports
Source: I deal with this myself quite a bit with the Gtk4 bindings I use for one of my projects.
-
How do I setup my Go environment?
Here's an actual module that I work on as an example.
-
moving to GUI from TUI
I've tried a number of them over the years but my latest attempt at a GUI project uses Gtk4.
-
Connect to home vpn
#1: Introducing Tailscale SSH | 13 comments #2: Tailscale devs sometimes contribute to Headscale #3: I got annoyed at the lack of a Linux GUI, so I built one myself. It's not finished by any means, but it can at least list peers and their IPs. | 1 comment
-
What is the coolest Go open source projects you have seen?
Yep. I was using manual WireGuard tunnels for that, but everytime I added a machine I had to configurations from both sides with manual key swaps, plus the fact that it I wanted direct connections between each machine the configuration would literally have increased exponentially. Tailscale handles all of that for me. Literally. It's primarily an automatic WireGuard tunnel coordinator. I just have to install it and log in and voila, it just works. I like it so much that I've actually got a project that wraps a GUI around Tailscale for Linux.
-
Go Developer Survey 2022 Q2 Results - The Go Programming Language
This is very likely. I've been writing a GUI wrapper for the Linux Tailscale client, and part of what I interact with from their libraries uses generics. In particular, they've got a views package that implements immutable containers.
Centrifugo
-
WebSockets vs. Server-Sent-Events vs. Long-Polling vs. WebRTC vs. WebTransport
Hello, I am author of https://github.com/centrifugal/centrifugo. Our users can choose from WebSocket, EventSource, WebTransport (experimental stabilize in the future). WebRTC is out of scope as the main purpose is central server based real-time json/binary messaging, and WebRTC makes things much more complex since it shines for peer-to-peer and rich media communications.
What I'd like to add is that Centrifugo also supports HTTP-streaming – not mentioned by the OP – but this is a transport which has advantages over Eventsource - like possibility to send POST body on initial request from web browser (with SSE you can not), it supports binary, and with Readable Streams browser API it's widely supported by modern browsers.
Another thing I'd like to mention about Centrifugo - it supports bidirectional WebSocket fallbacks with EventSource and HTTP-streaming, and does this without sticky sessions requirement. I guess nobody else have this at this point. See https://centrifugal.dev/blog/2022/07/19/centrifugo-v4-releas.... Which solves one more practical concern. Sticky sessions is an optimization in Centrifugo case, not a requirement.
If you are interested in topic, we also have a post about WebSocket scalability - https://centrifugal.dev/blog/2020/11/12/scaling-websocket - it covers some design decisions made in Centrifugo.
- Centrifugo v5.1.0 released, with new powers for real-time messaging tasks, now with proxy GRPC subscription streams – similar to WebSocketd but over the network
-
Integrating websockets into my current app
Check out https://github.com/centrifugal/centrifugo - it was initially designed to be a standalone language-agnostic real-time messaging server. So it may be used with Django without radical change in the existing application and using ASGI. It can also provide a much better performance if you care about it.
- Millions of Active WebSockets with Node.js
-
Show HN: DriftDB is an open source WebSocket back end for real-time apps
https://github.com/centrifugal/centrifugo
It's a complete solution, including server, admin panel and client library.
We're an European company and use OVH, Hetzner and others.
-
Laravel Websockets vs Soketi vs Laravel Echo Server
Hello! Theoretically you can take a look at https://github.com/centrifugal/centrifugo - which is a standalone self-hosted real-time messaging server. It does not have native support for Laravel and not compatible with Pusher protocol, though integrating with any backend system, including Laravel: see the blog post https://centrifugal.dev/blog/2021/12/14/laravel-multi-room-chat-tutorial, also has some helper packages:
-
Is Python a good option to implement Websockets?
Hello, it's also possible to design an app in a way that its core will be built with Python, but WebSocket part delegated to something external and efficient like https://github.com/centrifugal/centrifugo – the benefit of the approach is that application business logic is completely decoupled from the real-time transport layer. This may lead to a scalable design with graceful degradation. I think this is especially useful when you already have backend built with Django and need to handle millions of concurrent connections.
- Centrifugo – real-time messaging server (WebSocket, etc.) which scales well and integrates with any backend. SDKs for browser and mobile development included
-
What is the coolest Go open source projects you have seen?
Centrifugo https://centrifugal.dev/ https://github.com/centrifugal/centrifugo
- Golang updating the front-end with almost real-time events from the backend server
What are some alternatives?
tts-deckconverter - Generate card decks for Tabletop Simulator.
Socket.io - Realtime application framework (Node.JS server)
image-viewer - A simple image viewer with some editing functionality.
NATS - Golang client for NATS, the cloud native messaging system.
gotk4-adwaita - Autogenerated Adwaita bindings for Go
Confluent Kafka Golang Client - Confluent's Apache Kafka Golang client
TBitTorrent - BitTorrent client with terminal UI written in Go
Mercure - 🪽 An open, easy, fast, reliable and battery-efficient solution for real-time communications
fyne-cross - Cross compiler tool for Fyne apps
laravel-websockets - Websockets for Laravel. Done right.
headscale - An open source, self-hosted implementation of the Tailscale control server
soketi - Next-gen, Pusher-compatible, open-source WebSockets server. Simple, fast, and resilient. 📣