CentOS に MySQL8.0をインストールする

CentOS に MySQL8.0をインストールする

2021-01-263 min read

目次

  1. 概要
  2. はじめに
  3. 環境
  4. 起動
  5. mysqlインストール
  6. mycnf-の設定
  7. プロセス立ち上げ
  8. エラー
  9. 参考にさせていただいたサイト

概要

CentOS (8.3) に MySQL8.0をインストールして起動した際の記録です。 dockerで利用するためにmysqldから起動します。

はじめに

CentOS (8.3) に MySQL8.0をインストールして起動するのであれば systemctl などを使うことが一般的だと思いますが、 ここに記載する方法は systemctl を利用せず mysqld コマンドから立ち上げる方法です。 と言うのも Docker では systemctl を利用するのが厄介です。 色々ゴニョゴニョする必要があります。もちろん普通に立ち上げようとすると怒られます。 dockerコンテナ内でsystemdが動かないとかなんとか言われる。 - Tihiroのストレスフリーな生活

$ systemctl
System has not been booted with systemd as init system (PID 1). Can't operate.
Failed to connect to bus: Host is down

なので mysqld コマンドから起動する方法でセットアップしました。

環境

  • CentOS Linux release 8.3.2011
  • mysql Ver 8.0.21 for Linux on x86_64 (Source distribution)

起動

docker run --detach --name test -p 8080:80 --privileged  -it centos:8 /bin/bash
docker exec -it test bash

MySQLインストール

まずは以下のコマンドでmysql-serverをインストールします。clientも一緒にインストールされます。

dnf -y update
dnf -y install mysql-server

my.cnf の設定

/etc/my.cnf に 最低限の設定を記載します。

[mysqld]
user = mysql
default-authentication-plugin = mysql_native_password
lower_case_table_names = 0

プロセス立ち上げ

/usr/sbin/mysqld --user=mysql --initialize でプロセスを立ち上げます。

$ /usr/sbin/mysqld --user=mysql --initialize
2021-01-26T15:07:27.283529Z 0 [System] [MY-013169] [Server] /usr/sbin/mysqld (mysqld 8.0.21) initializing of server in progress as process 179
2021-01-26T15:07:27.291551Z 1 [System] [MY-013576] [InnoDB] InnoDB initialization has started.
2021-01-26T15:07:27.750767Z 1 [System] [MY-013577] [InnoDB] InnoDB initialization has ended.
2021-01-26T15:07:28.971631Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: PASSWORD # ← ランダムな文字列が表示される 

rootユーザのpasswordが表示される(PASSWORD)ので控えます。これでrootユーザでログインできるようになります。

$ /usr/sbin/mysqld --user=mysql & # バックグラウンドに移す
$ mysql -uroot -hlocalhost -p

エラー

The designated data directory /var/lib/mysql/ is unusable. You can remove all files that the server added to it.

The designated data directory /var/lib/mysql/ is unusable. You can remove all files that the server added to it.

こんなエラーがでたら /var/lib/mysql/ 以下を削除します。

rm -rf /var/lib/mysql/*

参考にさせていただいたサイト

Docker+CentOS8にnginx,PHP,MySQLをインストールしたコンテナを作成する - あるSEのつぶやき・改

dockerコンテナ内でsystemdが動かないとかなんとか言われる。 - Tihiroのストレスフリーな生活

Tags
javascript(103)
linux(54)
amazon%20aws(47)
node.js(43)
%E3%82%A2%E3%83%AB%E3%82%B4%E3%83%AA%E3%82%BA%E3%83%A0(36)
typescript(33)
%E7%94%BB%E5%83%8F%E5%87%A6%E7%90%86(30)
html5(29)
php(24)
centos(24)
python(22)
%E7%AB%B6%E6%8A%80%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0(21)
mac(21)
mysql(19)
canvas(18)
opencv(17)
%E9%9B%91%E8%AB%87(16)
docker(16)
wordpress(15)
atcoder(14)
apache(12)
%E6%A9%9F%E6%A2%B0%E5%AD%A6%E7%BF%92(12)
%E3%83%87%E3%83%BC%E3%82%BF%E3%83%99%E3%83%BC%E3%82%B9(12)
amazon%20s3(12)
red%20hat(12)
ubuntu(11)
github(10)
git(10)
vue.js(10)
%E7%94%BB%E5%83%8F%E5%87%A6%E7%90%86100%E6%9C%AC%E3%83%8E%E3%83%83%E3%82%AF(10)
mariadb(10)
aws%20cdk(9)
css3(8)
%E5%8F%AF%E8%A6%96%E5%8C%96(8)
%E5%B0%8F%E3%83%8D%E3%82%BF(8)
amazon%20lightsail(7)
react(7)
%E3%83%96%E3%83%AD%E3%82%B0(6)
cms(6)
oracle(6)
perl(6)
gitlab(6)
next.js(6)
prisma(6)
iam(5)
amazon%20ec2(5)
%E8%B3%87%E6%A0%BC%E8%A9%A6%E9%A8%93(5)
aws%20amplify(5)
nestjs(5)
curl(4)
Author
githubzennqiita
ただの備忘録です。※このブログの内容は個人の見解であり、所属する組織等の見解ではないです。