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

2021-01-26
mysqlmariadbcentoslinuxred%20hat
    

目次

概要

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のストレスフリーな生活

    

関連記事

AWS Amplify で コンテナベースのデプロイを行い REST API を構築
検証した環境 やってみる 初期準備 パイプラインを確認 終了処理 参考 AWS Amplify で コンテナベースのデプロイを行い REST API を構築した際のメモです。 検証した環境 amplify 5.1.…

Pythonでソケット通信を実装しメッセージの送受信を行う
ソース server.py client.py 動かしてみる 参考 Pythonでソケット通信を実現する方法です。 ソース server.py サーバ側のソースです。 client.py…

CentOS8 に Python + OpenCV をインストール
インストール テスト CentOS8 で標準で提供されているパッケージで Python + OpenCV 環境を構築する方法です。 検証した環境は CentOS8.3 (Docker) です。 インストール まず opencv…

[Perl] CentOS8 に plenv をインストール
インストール Step1 事前準備 Step2 PATHを通す (README通りにインストール) Step2 PATHを通す ($HOME以外にplenvをインストール) Step3 Perlインストール Step4 cpanmインストール CentOS…

CentOS6(Docker)でyum update できなくなった
エラー内容 対応 CentOS6.10 で yum update しようとしたところエラーが出てアップデートできなかったので対応した時の記録 エラー内容 以下のようなエラーが出ました。 対応 を以下のように変更したところ解決しました。

PostfixでメールリレーしてMailHogで受信する開発用Dockerコンテナの構築
環境 Dockerイメージ作成 コンテナの起動 telnetで送信テスト phpで送信テスト Postfixのリレーを介して送信されたメールをMailHog(開発用SMTPサーバ)でキャッチするDocker開発環境を構築した際のメモです。 環境 Docker…

php-fpmのステータスページを表示 Apache & htaccess
試した環境 php-fpm の pm.status_path について php-fpmのconfの設定 .htaccess の設定 アクセスしてみる 参考にしたサイト Apache環境で php-fpm のステータスページを htaccess…

DBクライアントツールはDBeaverをおすすめしたい
DBeaver について 特徴 対応DB 対応OS 利用環境 アーカイブ インストール windows mac Linux コネクションの作成 SQLを実行する その他 CloudBeaverについて 今までいくつかのDB…

CentOS8 に Oracle12.2 clientをインストールする
実施した環境 セットアップ clientツールの 準備 インストール 環境変数にパスを通す 実行 libnsl.so.1: cannot open shared object file と表示される場合 CentOS8 に Oracle12.2 client…

CentOS で スマートにプロキシを設定する
コマンドライン上で通す よりスマートに設定する 設定ファイルに記述 CentOSでプロキシを通す設定のメモです。 プロキシ環境で yum/dnf でリポジトリを更新する場合や、curl/wget…

最新の投稿

Node.js で作成した REST API を Docker化
Node.jsでREST APIを作成 コンテナ化 コンテナ化定義 コンテナ化作業 参考 Node.js で作成した REST API を Docker化した際のメモです。 Node.jsでREST APIを作成 まずはNode.js…

JavaScriptで優先度付きキューを実装する
優先度付きキューについて ソース 参考 JavaScriptで優先度付きキュー (プライオリティキュー) を実装する 優先度付きキューについて 具体的には次のような機能があります。 キューに対して要素を優先度付きで追加 (push…

AWS Amplify で コンテナベースのデプロイを行い REST API を構築
検証した環境 やってみる 初期準備 パイプラインを確認 終了処理 参考 AWS Amplify で コンテナベースのデプロイを行い REST API を構築した際のメモです。 検証した環境 amplify 5.1.…

Pythonでソケット通信を実装しメッセージの送受信を行う
ソース server.py client.py 動かしてみる 参考 Pythonでソケット通信を実現する方法です。 ソース server.py サーバ側のソースです。 client.py…

next_permutationをJSで実装する
ソース 使い方 参考 C++で提供されている順列を生成する next_permutation のJS実装です。 ソース 順列が存在する場合はtrueを返し、そうでなければfalse…

応用情報技術者試験の合格体験記
受験時のステータス 受験結果 対策 スケジュール 午前問題 午後問題 参考書等 令和…

[JS]ラジアンから度数に度数からラジアンに変換する
コード 度数からラジアンへ ラジアンから度数へ サンプル ラジアンから度数に度数からラジアンに変換する際のスニペット。 コード 度数からラジアンへ ラジアンから度数へ サンプル

CentOS8 に Python + OpenCV をインストール
インストール テスト CentOS8 で標準で提供されているパッケージで Python + OpenCV 環境を構築する方法です。 検証した環境は CentOS8.3 (Docker) です。 インストール まず opencv…

[Perl] CentOS8 に plenv をインストール
インストール Step1 事前準備 Step2 PATHを通す (README通りにインストール) Step2 PATHを通す ($HOME以外にplenvをインストール) Step3 Perlインストール Step4 cpanmインストール CentOS…

JS/TSのclassでclass名を取得する
コード JS/TSのconstructorを利用して自分自身のクラス名を取得する際のメモ。 コード このコードの結果は次のようになります。

Tags

Dates

s-yoshiki
s-yoshiki
githubtwitterqiita
Web作ってますが、インタラクティブなプログラミングも好きです。
JavaScript / Vue / node.js / PHP / AWS / OpenCV
© 2021   404 motivation not found