質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

Q&A

解決済

1回答

2251閲覧

Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) のエラー

EleAco

総合スコア15

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

0グッド

0クリップ

投稿2020/11/13 07:01

編集2020/11/13 23:49

##開発環境
Rails6
EC2
Mariadb
Nginx1
Unicorn

##行おうとしていたこと
EC2上でrailsを起動しようとすると

[ec2-user@ip-172-31-32-90 photo_roke]$ RAILS_SERVE_STATIC_FILES=1 unicorn_rails -c config/unicorn.rb -E production -D

このエラーが出て

master failed to start, check stderr log for details

stderr logを確認

less log/unicorn.stderr.log

するとしたのエラー分が出ました

##エラー文

Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

##行ったこと
エラー文からソケットがないよと言われていることを理解しました
ターミナルで今選択しているソケットを確認

[ec2-user@ip-172-31-32-90 photo_roke]$ mysql_config --socket /var/lib/mysql/mysql.sock

config.detabate.ymlにてソケットを確認

production: <<: *default database: photo_roke_production username: root password: <%= ENV['DATABASE_PASSWORD'] %> socket: /var/lib/mysql/mysql.sock

ここに間違いはないのでどのようにしたら良いか行き詰まってしまいました…
わかる方ご回答よろしくお願いいたします!

##追加コード
config.database.ymlファイル
の記述を全て載せておきます!!

# MySQL. Versions 5.5.8 and up are supported. # # Install the MySQL driver # gem install mysql2 # # Ensure the MySQL gem is defined in your Gemfile # gem 'mysql2' # # And be sure to use new-style password hashing: # https://dev.mysql.com/doc/refman/5.7/en/password-hashing.html # default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: socket: /tmp/mysql.sock development: <<: *default database: photo_roke_development # Warning: The database defined as "test" will be erased and # re-generated from your development database when you run "rake". # Do not set this db to the same as development or production. test: <<: *default database: photo_roke_test # As with config/credentials.yml, you never want to store sensitive information, # like your database password, in your source code. If your source code is # ever seen by anyone, they now have access to your database. # # Instead, provide the password as a unix environment variable when you boot # the app. Read https://guides.rubyonrails.org/configuring.html#configuring-a-database # for a full rundown on how to provide these environment variables in a # production deployment. # # On Heroku and other platform providers, you may have a full connection URL # available as an environment variable. For example: # # DATABASE_URL="mysql2://myuser:mypass@localhost/somedatabase" # # You can use this database configuration with: # # production: # url: <%= ENV['DATABASE_URL'] %> # production: <<: *default database: photo_roke_production username: root password: <%= ENV['DATABASE_PASSWORD'] %> socket: /var/lib/mysql/mysql.sock

##追加コード
sukekeke0さんご回答ありがとうございます!
行ったことをここに記述いたします!

(1) UNIXドメインソケットファイルが存在するか?

存在していませんでした

console

1/var/lib/mysql/mysql.sock

するとファイルがないとエラーが出たので
ファイルの作り方を調べて

console

1sudo touch /var/lib/mysql/mysql.sock 2sudo chown mysql:mysql /var/lib/mysql/mysql.sock

この二つを記述
もう一度

console

1/var/lib/mysql/mysql.sock

でファイルがあるか確認
すると権限がないとエラー
権限の渡し方を調べて

console

1sudo chmod 777 /var/lib/mysql/mysql.sock

これでよかったかわかりませんが権限を渡せた…と思います!
しかしそれ以降

console

1/var/lib/mysql/mysql.sock

を入力してもメッセージが返ってこなくなりました

一度インスタンスを再起動させMariaDBも再起動させ

console

1RAILS_SERVE_STATIC_FILES=1 unicorn_rails -c config/unicorn.rb -E production -D

を入力すると

Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (111)

エラー文が変わりました
すごく初歩的な疑問なのですが
使っているデータベースはMariaDBなのになぜMySQLのエラーが出るのでしょうか

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

下記を確認してみてください。

(1) UNIXドメインソケットファイルが存在するか?

console

1$ ls -l /var/lib/mysql/mysql.sock 2srwxrwxrwx 1 mysql mysql 0 Nov 13 22:51 /var/lib/mysql/mysql.sock

mysql_config --socketはデフォルトの生成先を表示しているだけです。
実際に存在するかどうかを示しているわけではありません。

(2) mariadbが起動しているか?

そもそもmariadbは起動していますか?
mariadbが起動していないと、UNIXドメインソケットファイルは生成されません。

console

1# systemctl status mariadb

(3) my.cnfでsocketファイルの生成先を指定していないか?

mariadbが起動しているのにも関わらず、(1)のファイルが存在しない場合、
/etc/my.conf, /etc/my.cnf.d/配下のファイルでsocket=を定義していないか?

socket=で指定したパスにUNIXドメインソケットファイルを生成します。

投稿2020/11/13 22:50

編集2020/11/14 00:15
sukekeke0

総合スコア331

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

EleAco

2020/11/13 23:52

sukekeke0さん 追加で書いた記述はちょっと書いていただいた内容をよく読まずに書いてしまっているので もう少し調べてからもう一度記述します!! >(3) my.cnfでsocketファイルの生成先を指定していないか? をまだ試していませんでした!!
EleAco

2020/11/14 00:04

sukekeke0さん >socket=で指定したパスにUNIXドメインソケットファイルを生成します。 ここは、具体的にどのような記述をしたら良いのでしょうか 全くの初学者のため理解がおいつていません…!! ご教示願います!
sukekeke0

2020/11/14 00:58 編集

> /var/lib/mysql/mysql.sock mariadb(mysqld)が生成するファイルです。 自分で勝手にtouch等でファイルを作っても意味はありません。(意味ないどころか有害なので削除してください) > すごく初歩的な疑問なのですが > 使っているデータベースはMariaDBなのになぜMySQLのエラーが出るのでしょうか MariaDBはMySQLから派生したソフトウェアです。 なので、プロセス名やメッセージはMySQL時代の名残です。
sukekeke0

2020/11/14 00:18 編集

> socket=で指定したパスにUNIXドメインソケットファイルを生成します。 > ここは、具体的にどのような記述をしたら良いのでしょうか > 全くの初学者のため理解がおいつていません…!! > ご教示願います! 記載がないなら気にしなくていいです。 デフォルトは/var/lib/mysql/mysql.sockで生成します。 例えば、socket=/aaa/bbb/ccc.sockと書いたなら、/aaa/bbb/ccc.sockが生成されるというだけのことです。 そもそも、/var/lib/mysql/mysql.sockが無いというのが問題です。 ちなみにですが、動かそうとしているNginx、UnicornやMariaDBは全て同じEC2上で動かしているのですか? UNIXドメインソケット(ここで言う/var/lib/mysql/mysql.sock)は通常、同じホスト上のプロセス間通信で使うものです。
sukekeke0

2020/11/14 00:15

> $ /var/lib/mysql/mysql.sock ↑は $ ls -l /var/lib/mysql/mysql.sockの誤記ですので修正しました。
sukekeke0

2020/11/14 00:28 編集

$ sudo systemctl status mariadb ● mariadb.service - MariaDB 10.3 database server Loaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled) Active: active (running) since Fri 2020-11-13 22:51:59 JST; 10h ago     ^^^^^^^^^^ ★failedになってたりしませんか?
EleAco

2020/11/14 00:38

>ちなみにですが、動かそうとしているNginx、UnicornやMariaDBは全て同じEC2上で動かしているのですか? 同じEC2内で動かそうとしています! >ls -l /var/lib/mysql/mysql.sock をターミナルで打つと -rwxrwxrwx 1 mysql mysql 0 11月 13 23:27 /var/lib/mysql/mysql.sock このようになりました! >$ sudo systemctl status mariadb ● mariadb.service - MariaDB 10.3 database server Loaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled) Active: active (running) since Fri 2020-11-13 22:51:59 JST; 10h ago     ^^^^^^^^^^ ★failedになってたりしませんか? よくみたところ ● mariadb.service - MariaDB database server Loaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled) Active: inactive (dead) 何か無効になっていました
sukekeke0

2020/11/14 00:57

mariadbが起動できていません。これが全ての原因です。 下記を実行してください。 $ sudo rm -f /var/lib/mysql/mysql.sock $ sudo systemctl start mariadb $ sudo systemctl status mariadb active(running)になっていることが確認できたら、あらためてソケットが存在するか確認してください。 $ ls -l /var/lib/mysql/mysql.sock
sukekeke0

2020/11/14 01:01

下記は、おまけの補足です。 $ ls -l /var/lib/mysql/mysql.sock srwxrwxrwx 1 mysql mysql 0 Nov 13 22:51 /var/lib/mysql/mysql.sock ^^ 先頭の"s"がソケットであることを示します。
EleAco

2020/11/14 01:10

sukekeke0さん ご丁寧にありがとうございます(;_;) active(running)になりました!しかし [ec2-user@ip-172-31-32-90 photo_roke]$ ls -l /var/lib/mysql/mysql.sock ls: /var/lib/mysql/mysql.sock にアクセスできません: No such file or directory となります
sukekeke0

2020/11/14 01:54 編集

順に試してみてください。 ------------------------------------- (1) mysql.sockが別の場所にないか探してみる $ sudo find / -name "mysql.sock" (2)(1)で見つからない場合、/etc/my.cnfにsocket=を指定してみる /etc/my.cnfの末尾にでも下記を追加。 ``` [mysqld] socket=/var/lib/mysql/mysql.sock ``` ``` $ sudo systemctl restart mariadb $ ls -l /var/lib/mysql/mysql.sock ``` lsで見つからなければ再度findで検索 ``` $ sudo find / -name "mysql.sock" ``` ------------------------------------- もしかすると、/tmp/systemd-private-xxxxx~にファイルがあるかもしれません。 その場合は別途対応が必要です。
EleAco

2020/11/14 02:02

sukekeke0さん 長い時間付き合っていただきありがとうございます!(;_;) >mysql.sockが別の場所にないか探してみる [ec2-user@ip-172-31-32-90 photo_roke]$ sudo find / -name "mysql.sock" /tmp/mysql.sock このように出ました これは見つけれていますか??
sukekeke0

2020/11/14 02:28 編集

それっぽいですね。 $ ls -l /tmp/mysql.sock ↑で見たら、ソケットファイルになっていますでしょうか? YESならば、お使いの環境にインストールしているMariaDBのsocketを生成するデフォルトパスが/tmp/mysql.sockなのか、どこかにsocket=/tmp/mysql.sockの定義があるのでしょう。 先ほど提示した(2)を試して(socket=/var/lib/mysql/mysql.sockを追加して)、/var/lib/mysql/mysql.sockが生成されれば解決すると思います。 念のため先に、"socket="の定義が無いか下記のように確認しておくと安心です。 $ grep -r "socket" /etc/my.cnf*
EleAco

2020/11/14 02:46

sukekeke0さん ありがとうございます [ec2-user@ip-172-31-32-90 photo_roke]$ ls -l /tmp/mysql.sock -rw-r--r-- 1 root root 0 11月 13 06:03 /tmp/mysql.sock (2)を試しました↓ [ec2-user@ip-172-31-32-90 photo_roke]$ socket=/var/lib/mysql/mysql.sock [ec2-user@ip-172-31-32-90 photo_roke]$ sudo systemctl restart mariadb [ec2-user@ip-172-31-32-90 photo_roke]$ ls -l /var/lib/mysql/mysql.sock srwxrwxrwx 1 mysql mysql 0 11月 14 02:32 /var/lib/mysql/mysql.sock これでできているということでしょうか??
sukekeke0

2020/11/14 02:51

>[ec2-user@ip-172-31-32-90 photo_roke]$ ls -l /var/lib/mysql/mysql.sock > srwxrwxrwx 1 mysql mysql 0 11月 14 02:32 /var/lib/mysql/mysql.sock > これでできているということでしょうか?? はい、出来てます。 再度、railsで作ったアプリから接続できるか試してみてください。 > [ec2-user@ip-172-31-32-90 photo_roke]$ ls -l /tmp/mysql.sock > -rw-r--r-- 1 root root 0 11月 13 06:03 /tmp/mysql.sock これは、ちょっと予想と違いました… ですが、上手くいったようなので気にしないことにします。
sukekeke0

2020/11/14 02:55 編集

> はい、出来てます。 確実に出来ているかを確認するには下記コマンド見るといいと思います。 $ sudo ss -axp |grep mysql u_str LISTEN 0 80 /var/lib/mysql/mysql.sock 738232 * 0 users:(("mysqld",pid=14405,fd=22)) ↑mysqldが/var/lib/mysql/mysql.sock で待ち受けていればOK
EleAco

2020/11/14 02:59

sukekeke0さん 本当ご丁寧にありがとうございます(;_;) [ec2-user@ip-172-31-32-90 photo_roke]$ sudo ss -axp |grep mysql u_strLISTEN 0 50 /var/lib/mysql/mysql.sock 23073 * 0 users:(("mysqld",pid=3976,fd=15)) [ec2-user@ip-172-31-32-90 photo_roke]$ できていますね!! ちょっと今 [ec2-user@ip-172-31-32-90 photo_roke]$ RAILS_SERVE_STATIC_FILES=1 unicorn_rails -c config/unicorn.rb -E production -D [ec2-user@ip-172-31-32-90 photo_roke]$ 起動するように促しても何も返事をしなくなったのでちょっと起動できるまでお待ちください…
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問