Need advice about which tool to choose?Ask the StackShare community!

goa

18
42
+ 1
0
seneca

28
42
+ 1
2
Add tool

goa vs seneca: What are the differences?

goa: A design driven approach for building microservices in Go. goa is a framework for building microservices in Go using a unique design-first approach. goa provides a novel approach for developing microservices that saves time when working on independent services and helps with keeping the overall system consistent; seneca: A Micro-Services toolkit for Node.js. Seneca is a toolkit for organizing the business logic of your app. You can break down your app into "stuff that happens", rather than focusing on data models or managing dependencies.

goa and seneca belong to "Microservices Tools" category of the tech stack.

Some of the features offered by goa are:

  • Creating a service with goa starts with the design. The goa DSL lets you describe the global properties, types and endpoints that make up the service API. The apidsl package docs provides a quick reference to all the DSL functions.
  • Once the design of the API is in place goagen generates the corresponding data structures, validation code and handlers. Handlers are defined as interface methods. Implementing the service is thus as simple as implementing the generated interfaces.
  • The best part about the goa DSL is that the engine is completely decoupled. Plugins can implement custom DSLs to extend the concepts described in the design. Plugins can also generate arbitrary outputs.

On the other hand, seneca provides the following key features:

  • pattern matching: a wonderfully flexible way to handle business requirements
  • transport independence: how messages get to the right server is not something you should have to worry about
  • maturity: 5 years in production (before we called it micro-services), but was once taken out by lightning

goa and seneca are both open source tools. goa with 3.46K GitHub stars and 389 forks on GitHub appears to be more popular than seneca with 3 GitHub stars and 1 GitHub forks.

Get Advice from developers at your company using StackShare Enterprise. Sign up for StackShare Enterprise.
Learn More
Pros of goa
Pros of seneca
    Be the first to leave a pro
    • 2
      Multi transports support

    Sign up to add or upvote prosMake informed product decisions

    What is goa?

    goa is a framework for building microservices in Go using a unique design-first approach. goa provides a novel approach for developing microservices that saves time when working on independent services and helps with keeping the overall system consistent.

    What is seneca?

    Seneca is a toolkit for organizing the business logic of your app. You can break down your app into "stuff that happens", rather than focusing on data models or managing dependencies.

    Need advice about which tool to choose?Ask the StackShare community!

    What companies use goa?
    What companies use seneca?
    See which teams inside your own company are using goa or seneca.
    Sign up for StackShare EnterpriseLearn More

    Sign up to get full access to all the companiesMake informed product decisions

    What tools integrate with goa?
    What tools integrate with seneca?
    What are some alternatives to goa and seneca?
    Istio
    Istio is an open platform for providing a uniform way to integrate microservices, manage traffic flow across microservices, enforce policies and aggregate telemetry data. Istio's control plane provides an abstraction layer over the underlying cluster management platform, such as Kubernetes, Mesos, etc.
    Zuul
    It is the front door for all requests from devices and websites to the backend of the Netflix streaming application. As an edge service application, It is built to enable dynamic routing, monitoring, resiliency, and security. Routing is an integral part of a microservice architecture.
    Jersey
    It is open source, production quality, framework for developing RESTful Web Services in Java that provides support for JAX-RS APIs and serves as a JAX-RS (JSR 311 & JSR 339) Reference Implementation. It provides it’s own API that extend the JAX-RS toolkit with additional features and utilities to further simplify RESTful service and client development.
    linkerd
    linkerd is an out-of-process network stack for microservices. It functions as a transparent RPC proxy, handling everything needed to make inter-service RPC safe and sane--including load-balancing, service discovery, instrumentation, and routing.
    Azure Service Fabric
    Azure Service Fabric is a distributed systems platform that makes it easy to package, deploy, and manage scalable and reliable microservices. Service Fabric addresses the significant challenges in developing and managing cloud apps.
    See all alternatives