ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
警告メッセージ
Warning: World-writable config file '/etc/mysql/my.cnf' is ignored
# または
$ mysql
Warning: World-writable config file '/home/app/.my.cnf' is ignored
MySQL クライアント / サーバが設定ファイルを読み込もうとしたとき、そのファイルが全ユーザー書き込み可能(other に w ビット)だと、セキュリティ上の理由でそのファイルを無視します。同様に ~/.my.cnf は所有者以外に読み権限があるだけで警告が出ます。
なぜ無視するのか
my.cnf は MySQL の起動オプションをそのまま指定できる強力な設定ファイルです。誰でも書き換えられる状態だと:
plugin-loadで任意のコードをロードさせて mysqld 権限で実行可能secure_file_privを緩めてファイル漏洩skip-grant-tablesを仕込んで認証回避
これらは実質サーバ乗っ取りに直結するため、MySQL は意図的に「危険なパーミッションの設定ファイルは読まない」挙動を取ります。
パーミッションの確認
ls -l /etc/mysql/my.cnf
# -rw-rw-rw- 1 root root 1234 May 17 10:00 /etc/mysql/my.cnf ← world-writable
# 数値表記で確認
stat -c '%a %U:%G %n' /etc/mysql/my.cnf
# 666 root:root /etc/mysql/my.cnf ← NG (other に w)
# ~/.my.cnf
ls -l ~/.my.cnf
stat -c '%a %U:%G %n' ~/.my.cnf
対処: パーミッションを修正
| ファイル | 推奨パーミッション | 所有者 |
|---|---|---|
/etc/my.cnf / /etc/mysql/my.cnf | 644 | root:root |
/etc/mysql/conf.d/*.cnf | 644 | root:root |
~/.my.cnf(パスワード入り) | 600 | 自分 |
/etc/mysql/debian.cnf(Ubuntu) | 640 | root:root |
# 一般的な my.cnf
sudo chmod 644 /etc/mysql/my.cnf
sudo chown root:root /etc/mysql/my.cnf
# パスワード入りの ~/.my.cnf は 600
chmod 600 ~/.my.cnf
chown $(whoami):$(whoami) ~/.my.cnf
# conf.d 配下を一括
sudo chmod 644 /etc/mysql/conf.d/*.cnf
sudo chmod 644 /etc/mysql/mysql.conf.d/*.cnf
# 再確認
ls -l /etc/mysql/my.cnf
mysql --help | grep -A 1 "Default options" # 認識されているかを確認
所有者違いで読み込まれないケース
~/.my.cnf を root で作って一般ユーザーで使うと、ファイルの所有者と実行者が違うために警告が出ることがあります:
# 自分のホームに自分所有で作る
whoami # → app
ls -l ~/.my.cnf # -rw------- 1 app app ... OK
# ❌ root で作って配置だけしたケース
sudo cp /root/.my.cnf /home/app/.my.cnf
ls -l /home/app/.my.cnf
# -rw------- 1 root root ... ← 警告が出る
# ✅ 所有者を直す
sudo chown app:app /home/app/.my.cnf
chmod の数字の読み方
| 数値 | 権限 | 表記 | 用途 |
|---|---|---|---|
600 | 所有者 rw のみ | -rw------- | パスワード入りファイル |
640 | 所有者 rw / グループ r | -rw-r----- | 共有が必要だが秘匿したい |
644 | 所有者 rw / 他 r | -rw-r--r-- | 一般的な設定ファイル |
666 | 全員 rw (危険) | -rw-rw-rw- | 使わない |
755 | 所有者 rwx / 他 rx | -rwxr-xr-x | 実行ファイル・ディレクトリ |
影響: 無視された結果どうなるか
my.cnf が無視されると、その中の設定がすべて反映されません。たとえば:
character-set-server=utf8mb4が効かず latin1 になるbind-address=0.0.0.0が効かず localhost からしか繋げないmax_connections=500が効かず既定の 151 で頭打ち
「設定を変えたのに反映されない」場合は必ず警告ログを確認してください。
警告を出さずに動作確認
# クライアントで認識した変数値
mysql -e "SELECT @@character_set_server, @@bind_address, @@max_connections"
# サーバ起動時に読まれた my.cnf 一覧
mysqld --verbose --help 2>&1 | grep -A 1 "Default options"
# 起動ログ(systemd)
journalctl -u mysql -n 100
sudo tail -n 100 /var/log/mysql/error.log
関連する設定ファイルの場所
| OS / 配布 | 主な場所 |
|---|---|
| Ubuntu / Debian | /etc/mysql/my.cnf + /etc/mysql/mysql.conf.d/mysqld.cnf |
| RHEL / CentOS / Rocky | /etc/my.cnf + /etc/my.cnf.d/*.cnf |
| macOS Homebrew | /opt/homebrew/etc/my.cnf |
| 共通(ユーザー) | ~/.my.cnf(要 600) |
FAQ
Q: 警告は出るが MySQL は起動する
A: そのファイルが無視されただけで起動はします。中身の設定は効いていないので、業務影響を確認してください。
Q: なぜ 666 になっていた?
A: 過去に chmod 666 を実行した、Samba で Windows からコピーした、umask が異常、root 以外の編集を許すために緩めた、などが典型。
Q: SELinux でも似た現象?
A: SELinux の場合は警告メッセージが違います(permission denied や AVC denied)。ls -lZ でコンテキスト確認、restorecon で復旧。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- 1071 Specified key was too long; max key length is 767 bytes
- ERROR 1063 (42000): Incorrect column specifier for column '~'
- mysqld: Can't change dir to '...\MySQL\MySQL Server X.X\data\' (OS errno 2 - No such file or directory)
- Install/Remove of the Service Denied!
- Datetime 型が NULL に見える
- Warning: World-writable config file '/etc/mysql/my.cnf' is ignored
- ERROR 1698 (28000): Access denied for user 'root'@'localhost'
- Exception: Wrong MySQL configuration
- [Warning] TIMESTAMP with implicit DEFAULT value is deprecated.
- ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
- ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
- Incorrect column specifier for column 'カラム名'
- BLOB/TEXT column 'description' used in key specification without a key length
- ERROR: /bin/sh: mysql_config: コマンドが見つかりません
- Host '...' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts'
- CSVエクスポート時に「ERROR 1045 (28000): Access denied for user 'username'@'localhost'」エラーが表示される
- Cannot execute statement: impossible to write to binary log since BINLOG_FORMAT = STATEMENT
- 1
- 1
- 1)
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1"'`--
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1)
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1"'`--
- 1
- 1
- SQLSTATE[22007]: Invalid datetime format: 1366 Incorrect string value: ~
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?