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

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

新規登録して質問してみよう
ただいま回答率
85.35%
MySQL

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

ソケット

TCP/IPにおいて、IPアドレスとサブアドレスであるポート番号を組み合わせたネットワークアドレスのことを呼びます。また、ソフトウェアアプリケーションにおいて、TCP/IP通信を行う為の仮想的なインターフェースという意味もある。

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

2回答

2210閲覧

【mysql,本番環境】ソケット経由でローカルMySQLサーバーに接続できない

akaki

総合スコア15

MySQL

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

ソケット

TCP/IPにおいて、IPアドレスとサブアドレスであるポート番号を組み合わせたネットワークアドレスのことを呼びます。また、ソフトウェアアプリケーションにおいて、TCP/IP通信を行う為の仮想的なインターフェースという意味もある。

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

1クリップ

投稿2020/06/15 07:03

編集2020/06/15 10:26

前提・実現したいこと

いつもお世話になっております。
本番環境でmysqlを起動できず、対応に苦慮しています。
昨日までは問題なく起動できていましたが、本日急にソケット?のエラーになり、mysqlにログインできなくなりました。

具体的には、「mysql -u root -p」でログインしようとすると下記のエラーになります。

[user@ip-10-0-10-10 soup]$ mysql -u root -p ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

mysqlを再起動しようとすると、このようなエラーになります。

[user@ip-10-0-10-10 soup]$ service mysqld restart Restarting mysqld (via systemctl): Failed to restart mysqld.service: The name org.freedesktop.PolicyKit1 was not provided by any .service files See system logs and 'systemctl status mysqld.service' for details. [FAILED]

「systemctl status mysqld.service」を実行して状態を確認するとこうなります。

[user@ip-10-0-10-10 soup]$ systemctl status mysqld.service ● mysqld.service - SYSV: MySQL database server. Loaded: loaded (/etc/rc.d/init.d/mysqld; bad; vendor preset: disabled) Active: failed (Result: exit-code) since 月 2020-06-15 06:36:14 UTC; 13min ago Docs: man:systemd-sysv-generator(8) Process: 14706 ExecStop=/etc/rc.d/init.d/mysqld stop (code=exited, status=0/SUCCESS) Process: 17398 ExecStart=/etc/rc.d/init.d/mysqld start (code=exited, status=1/FAILURE) Main PID: 8819 6月 15 06:36:13 ip-10-0-10-10.ap-northeast-1.compute.internal systemd[1]: Starting SYSV: MySQL database server.... 6月 15 06:36:14 ip-10-0-10-10.ap-northeast-1.compute.internal mysqld[17398]: MySQL Daemon failed to start. 6月 15 06:36:14 ip-10-0-10-10.ap-northeast-1.compute.internal systemd[1]: mysqld.service: control process exited, code=exited status=1 6月 15 06:36:14 ip-10-0-10-10.ap-northeast-1.compute.internal mysqld[17398]: Starting mysqld: [FAILED] 6月 15 06:36:14 ip-10-0-10-10.ap-northeast-1.compute.internal systemd[1]: Failed to start SYSV: MySQL database server.. 6月 15 06:36:14 ip-10-0-10-10.ap-northeast-1.compute.internal systemd[1]: Unit mysqld.service entered failed state. 6月 15 06:36:14 ip-10-0-10-10.ap-northeast-1.compute.internal systemd[1]: mysqld.service failed.

mysqlの状態は下記のようになっており、起動できておりません。

[user@ip-10-0-10-10 soup]$ ps ax | grep mysqld 17809 pts/2 S+ 0:00 grep --color=auto mysqld

「database.yml」の記述は下記です。

default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: socket: /tmp/mysql.sock production: adapter: mysql2 encoding: utf8 pool: 5 database: soup_production username: root password: <%= ENV['SOUP_DATABASE_PASSWORD'] %> socket: /var/lib/mysql/mysql.sock

対策をお聞きしたいです。

試したこと

参考記事
最初、mysql.sockのディレクトリが存在しなかったため、こちらを試しました。

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

その後、エラー内容
「'/var/lib/mysql/mysql.sock' (2)」が
「'/var/lib/mysql/mysql.sock' (111)」に変わりました。

現在は対応策がつかめないため、一旦mysql.sockを削除しています。

補足情報(FW/ツールのバージョンなど)

mysql5.6

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

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

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

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

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

guest

回答2

0

自己解決

swapの容量が足りていないというエラーでした!こちら解決しました。

投稿2020/06/15 13:49

akaki

総合スコア15

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

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

0

socket: /tmp/mysql.sock

が二重にかかれていますので、それでおかしくなってるのかと。

<<: *default

とはdefaultの中のものをそこに記載するという意味なので、productionの中身がが

production: adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: socket: /tmp/mysql.sock adapter: mysql2 encoding: utf8 pool: 5 database: soup_production username: root password: <%= ENV['SOUP_DATABASE_PASSWORD'] %> socket: /var/lib/mysql/mysql.sock

になります。

投稿2020/06/15 07:14

Mashiro

総合スコア654

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

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

akaki

2020/06/15 07:21

返信ありがとうございます! 本番環境のdatabase.ymlをこのように修正しましたが、まだ同様のエラーになってしまいます。 https://i.gyazo.com/cdd4c2873a18808a32e1df22df91ba93.png ローカルから内容を変更して、本番環境でgit pull方がいいでしょうか?初学者のため、対策がうまく思いつかずすみません、、
Mashiro

2020/06/15 07:30

socketだけじゃなくて、adapterやencodingやusernameなども2重になってます。基本的にはdefaultに記載されてないものだけproductionの中に書きましょう。
akaki

2020/06/15 09:39

ありがとうございます!修正しましたが、まだmysqlにログインできませんでした、、、 <エラー内容> ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) ※mysql.sock' (2) カッコ内の数字が変わったのは、mysql.sockを一旦削除したためです。 参考記事:https://www.ten-kyuu.com/error-socket/ mysqlをスタートさせようとしてもエラーが継続しています。それ以外に原因は考えられますでしょうか。
akaki

2020/06/15 10:12

もう少し自分で考えて見て、それでも厳しそうなら新しく質問を立てようと思います! Mashiroさん、ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問