Need help with go-on-rails?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

276 Stars 18 Forks MIT License 296 Commits 4 Opened issues


:bullettrain_side: Use Rails to Develop or Generate a Golang Application.

Services available


Need anything else?

Contributors list

Go on Rails

Use Rails to generate Golang code or manage Go app development

Gem Version Build Status Maintainability MIT License

用 Rails 开发 Go 应用:中文文档

is a Rails generator aims to:
  1. Help to develop and integrate some APIs written in Golang to existing Rails app for high performance
  2. Use your familiar Rails tools to develop and manage a Golang app project
  3. Convert a not very complicated Rails app to Golang equivalent

Here's some examples: * A simple example(tutorial) on the basic usage of go-on-rails generator * An advanced example shows how to integrate Go APIs in a Rails project * Another example shows how to handle a Rails session to get a user's info in a go-on-rails generated Go API


  • Rails 4.2+ (Rails 6 not supported and need your help)
  • Golang 1.10.x(mainly be compatible with


Add this line to your application's Gemfile:

gem 'go-on-rails', '~> 0.4.0'

And then execute:

$ bundle

Or install it yourself as:

$ gem install go-on-rails


You must have an existing Rails app or to create a new one before you try go-on-rails to generate Golang codes.

After that you can run the command just as other Rails generators:

rails g gor [dev(elopment) | pro(duction) | test | ...] [-m model_a model_b model_c ...]

OR (on rails version < 5.0)

rake g gor ...

here we take generating all models for the

environment for example:
rails g gor dev

Then a folder named

that includes Golang codes will be generated under your Rails app root path.

Install the dependent Golang packages for this Go project:

rails gor:deps

Then change to the

directory and run:
go run main.go

You can visit the page in http://localhost:4000 by default.

More command details about go-on-rails generator:

rails g gor --help

What will be generated?

  • Go project directory layout (all under the
    directory, like
  • A Go data struct corresponding to each activerecord model
  • And each struct related CRUD functions/methods like FindModel, UpdateModel, DestroyModel etc. All these models related program files under the
  • And godoc files for all the functions under
  • We use Gin as the default web framework, but you can change it to anyone that you favor in

View the godoc of all functions

You can view the godoc page of all functions in http://localhost:7979/doc/models.html after run:

rails gor:doc

Besides, there's a sample project generated by go-on-rails, you can view its godoc at just now to get a picture of what functions are generated.

Known issues and TODOs

The gem is still under development, so there're some known issues. You're welcomed to contribute. 👏

  • databases specific functions between MySQL and Postgres or other databases are not covered completely
  • sql.NullType not supported yet, so you'd better in the migrations set those columns "not null" with a default value that's consistent with Golang's zero value specification, such as "" default for string and text typed column, and 0 default for int, etc. And now we have an alternative approach for manipulating the database nullable fields, see the wiki Working with database nullable fields

  • [x] Associations

    • [x] has_many
    • [x] has_one
    • [x] belongs_to
    • [x] dependent
  • [x] Validations

    • [x] length
    • [x] presence
    • [x] format(string only)
    • [x] numericality(partially)
    • [ ] other validations
  • [x] Pagination(details see wiki)

  • [ ] Callbacks

  • [ ] Transactions

Supported databases

  • SQLite
  • MySQL
  • Postgres


Golang dependencies by default


When I had the idea to convert Rails app or build Golang app with Rails tools, I searched github and found the project: And from ar2gostruct I copied some codes on handling data structure conversion and models association, it made my idea come true faster than I imagined.


There're two branches at present:



branch has a whole Rails environment for development: models, seeds for testing, and under
directory there's a file named
used to test generated Golang codes.
  • Fork the project switch to branch
  • Make your feature addition or bug fix.
  • Add tests for it. This is important so I don't break it in a future version unintentionally.
  • Commit, do not mess with Rakefile or version (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)
  • Send me a pull request. Bonus points for topic branches.


We create four models for testing:

  • Physician
  • Patient
  • Appointment
  • Picture


rails db:seed
to use the data defined in
. And change to
directory to run
go test
to test generated models-related functions. The test covers a small part of the functions currently. More will be added later on.


See the LICENSE file.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.