Hi Everyone,

I'm interested in improving my software engineering knowledge and 
experience with scalable software systems. I currently write software for 
an environment that's more resource-constrained (think embedded Linux 
device) where there is typically only one user connected to the device and 
interacting with the software API at a time. We optimize for efficient 
interaction with hardware (button events, transcoding, scanning 
filesystems, thumbnail generation, etc). This is the world in which I've 
grown as a professional software engineer and I'm looking to expand my 
knowledge to software applications outside of embedded Linux environments.

'm looking to learn more about designing and implementing larger systems 
that are designed to handle hundreds or thousands of concurrent users, and 
I would appreciate any insight on how they learned about this type of 
software engineering and what resources they found useful. Specifically, 
I've been asking myself the following questions:

   - What are some common design patterns used for scalable systems?
   - What technologies are commonly used for scalable systems? I'm familiar 
   with protocol buffers and Twirp, an RPC library that leverages protobufs. 
   I'd love to learn more about caching, transport mechanisms, and databases.
   - Are there any books, articles, or other reference material you've 
   found helpful for expanding your knowledge of designing systems at scale?


Currently I've started a couple of side projects to explore this space:

   - A library that monitors the number of open files given one or more 
   PIDs. I would like to build upon this idea by creating a custom 
   exporter/collector for node_exporter so that I could integrate this nicely 
   in an existing monitoring setup. My goal with this project is to connect my 
   knowledge of Linux and the constraints on processes with some common 
   monitoring technologies that might be found in a large software ecosystem.
   - An AWS Lambda function that interacts with a couple of 3rd party APIs, 
   namely Reddit and Spotify. My goal with this project is to learn a bit 
   about 3rd party API consumption and serverless design.

One caveat of which I'm aware is that these thoughts are not very specific 
to Go, and that often the programming language used to implement an 
application is part of the solution to a particular problem. I'm just 
particularly focusing on Go because I'm familiar with it as a systems-level 
language but would love to learn how Go is used to design larger-scale 
applications.

I'm very open to suggestions with regards to the questions above, or 
anything else in this space that might be helpful as I start this journey. 
Thanks in advance for any insight you might be able to share!

Cheers,
Rob Weber

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/7f45b116-b9a8-44f7-b3d0-fdb4fe23d26c%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to