Search code examples
ruby-on-rails

'rails server' command returns error: `mkdir': Permission denied @ dir_s_mkdir


I am trying to run a rails server sample that I downloaded. But, I am getting a permissions error:

I run:

rails server

I get:

=> Booting Puma
=> Rails 4.2.4 application starting in development on http://localhost:3000
=> Run `rails server -h` for more startup options
=> Ctrl-C to shutdown server
Exiting
/usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:250:in `mkdir': Permission denied @ dir_s_mkdir - /home/username/web-app/tmp (Errno::EACCES)
    from /usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:250:in `fu_mkdir'
    from /usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:224:in `block (2 levels) in mkdir_p'
    from /usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:222:in `reverse_each'
    from /usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:222:in `block in mkdir_p'
    from /usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:208:in `each'
    from /usr/share/rvm/rubies/ruby-2.1.7/lib/ruby/2.1.0/fileutils.rb:208:in `mkdir_p'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/server.rb:134:in `block in create_tmp_directories'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/server.rb:133:in `each'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/server.rb:133:in `create_tmp_directories'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/server.rb:77:in `start'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/commands_tasks.rb:80:in `block in server'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/commands_tasks.rb:75:in `tap'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/commands_tasks.rb:75:in `server'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands/commands_tasks.rb:39:in `run_command!'
    from /home/username/.rvm/gems/ruby-2.1.7/gems/railties-4.2.4/lib/rails/commands.rb:17:in `<top (required)>'
    from bin/rails:4:in `require'
    from bin/rails:4:in `<main>'

Seeing that it was a permissions error I tried:

sudo rails server

But I only received this error

Your Ruby version is 1.9.3, but your Gemfile specified 2.1.7

How do I overcome the permissions problem when the root user seems to be using a different version of ruby?

EDIT 1:

ruby --version

returns:

ruby 2.1.7p400 (2015-08-18 revision 51632) [i686-linux]

EDIT 2:

sudo ruby --version

returns:

ruby 1.9.3p484 (2013-11-22 revision 43786) [i686-linux]

EDIT 3:

There is no tmp file in my web-app directory. When I type ls -la I get:

drwxr-xr-x 12 root    root     4096 Nov 15 10:32 .
drwxr-xr-x 31 username username 4096 Nov 17 04:23 ..
drwxr-xr-x 10 root    root     4096 Nov 15 10:32 app
drwxr-xr-x  2 root    root     4096 Nov 15 10:32 bin
-rw-r--r--  1 root    root      126 Nov 15 10:32 browserslist
-rw-r--r--  1 root    root      363 Nov 15 10:32 Capfile
drwxr-xr-x  6 root    root     4096 Nov 15 10:32 config
-rw-r--r--  1 root    root      153 Nov 15 10:32 config.ru
drwxr-xr-x  3 root    root     4096 Nov 15 10:32 db
-rw-r--r--  1 root    root     1301 Nov 15 10:32 Gemfile
-rw-r--r--  1 root    root    10953 Nov 15 10:32 Gemfile.lock
drwxr-xr-x  8 root    root     4096 Nov 15 10:32 .git
-rw-r--r--  1 root    root      470 Nov 15 10:32 .gitignore
drwxr-xr-x  4 root    root     4096 Nov 15 10:32 lib
drwxr-xr-x  2 root    root     4096 Nov 15 10:32 log
drwxr-xr-x  2 root    root     4096 Nov 15 10:32 public
-rw-r--r--  1 root    root      249 Nov 15 10:32 Rakefile
-rw-r--r--  1 root    root      478 Nov 15 10:32 README.rdoc
-rw-r--r--  1 root    root        8 Nov 15 10:32 .rspec
drwxr-xr-x  3 root    root     4096 Nov 15 10:32 spec
drwxr-xr-x  3 root    root     4096 Nov 15 10:32 vendor

Solution

  • First one must create the tmp directory, then give it the necessary permissions. This can be done with the following code:

    sudo mkdir tmp
    sudo chmod 777 tmp