MYSQL インストール
cent os 6.9
yumでインストール
sudo yum install mysql mysql-server mysql-devel -y
存在確認
whichで確認
which mysql
mysql version確認
version
mysql --version
mysql Ver 14.14 Distrib 5.1.73, for redhat-linux-gnu (x86_64) using readline 5.1
mysql デーモン 起動
sudo service mysqld start
mysql 自動起動
sudo chkconfig mysqld on
下記で安全にインストール
mysql_secure_installation
NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL
SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
In order to log into MySQL to secure it, we'll need the current
password for the root user. If you've just installed MySQL, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.
Enter current password for root (enter for none):
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
Enter current password for root (enter for none):
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
Enter current password for root (enter for none):
OK, successfully used password, moving on...
Setting the root password ensures that nobody can log into the MySQL
root user without the proper authorisation.
Set root password? [Y/n] Y <= 左記以降でパスワードを聞かれるので登録します。
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
... Success!
By default, a MySQL installation has an anonymous user, allowing anyone
to log into MySQL without having to have a user account created for
them. This is intended only for testing, and to make the installation
go a bit smoother. You should remove them before moving into a
production environment.
Remove anonymous users? [Y/n] Y
... Success!
Normally, root should only be allowed to connect from 'localhost'. This
ensures that someone cannot guess at the root password from the network.
Disallow root login remotely? [Y/n] Y <= リモートからルートpでログインできななのを停止。
... Success!
By default, MySQL comes with a database named 'test' that anyone can
access. This is also intended only for testing, and should be removed
before moving into a production environment.
Remove test database and access to it? [Y/n] Y
- Dropping test database...
... Success!
- Removing privileges on test database...
... Success!
Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.
Reload privilege tables now? [Y/n] Y
... Success!
Cleaning up...
All done! If you've completed all of the above steps, your MySQL
installation should now be secure.
Thanks for using MySQL!
innoDBエンジンが優れてるっぽい、スナップショットとかしてるし、
早そうなので採用
/etc/my.cnf
[mysqld]
default-storage-engine=InnoDB
innodb_file_per_table
mysql 再起動
sudo service mysqld restart
mysqld を停止中: [ OK ]
mysqld を起動中: [ OK ]
mysql ルートでログイン
先ほど設定したパスワードでログイン
mysql -uroot -p
mysql ユーザー追加
権限はなんでもありで設定
GRANT ALL PRIVILEGES ON *.* TO username@localhost;
FLUSH PRIVILEGES; #権限反映
もしくわ
grant all privileges on *.* to username@localhost identified by 'password';
上記は権限全て付与状態ですが権限に関しましては下記を参照
表13.3 GRANTおよびREVOKEの許可特権
特権 | 意味と授与可能レベル |
---|---|
ALL [PRIVILEGES] | GRANT OPTIONおよび を除く指定されたアクセスレベルですべての特権を許可します PROXY。 |
ALTER | の使用を有効にしますALTER TABLE。レベル:グローバル、データベース、テーブル。 |
ALTER ROUTINE | ストアドルーチンを変更または削除できるようにします。レベル:グローバル、データベース、プロシージャ |
CREATE | データベースとテーブルの作成を有効にします。レベル:グローバル、データベース、テーブル。 |
CREATE ROUTINE | ストアドルーチンの作成を有効にします。レベル:グローバル、データベース。 |
CREATE TABLESPACE | 表領域とログ・ファイル・グループを作成、変更、または削除できるようにします。レベル:グローバル。 |
CREATE TEMPORARY TABLES | の使用を有効にしますCREATE TEMPORARY TABLE。レベル:グローバル、データベース。 |
CREATE USER | 使用を有効にCREATE USER、 DROP USER、 RENAME USER、とします REVOKE ALL PRIVILEGES。レベル:グローバル。 |
CREATE VIEW | ビューを作成または変更できるようにします。レベル:グローバル、データベース、テーブル。 |
DELETE | の使用を有効にしますDELETE。レベル:グローバル、データベース、テーブル。 |
DROP | データベース、テーブル、およびビューを削除できるようにします。レベル:グローバル、データベース、テーブル。 |
EVENT | イベントスケジューラのイベントの使用を有効にします。レベル:グローバル、データベース。 |
EXECUTE | ユーザがストアドルーチンを実行できるようにする。レベル:グローバル、データベース、テーブル。 |
FILE | ユーザーがサーバーにファイルの読み取りまたは書き込みを行えるようにします。レベル:グローバル。 |
GRANT OPTION | 他のアカウントとの権限の付与または削除を可能にする。レベル:グローバル、データベース、テーブル、プロシージャ、プロキシ |
INDEX | インデックスの作成または削除を有効にします。レベル:グローバル、データベース、テーブル。 |
INSERT | の使用を有効にしますINSERT。レベル:グローバル、データベース、テーブル、カラム。 |
LOCK TABLES | 特権LOCK TABLESを持っているテーブルでの 使用を有効にしますSELECT。レベル:グローバル、データベース。 |
PROCESS | ユーザーがすべてのプロセスを表示できるようにしSHOW PROCESSLISTます。レベル:グローバル。 |
PROXY | ユーザーのプロキシを有効にします。レベル:ユーザーからユーザーまで。 |
REFERENCES | 外部キーの作成を有効にします。レベル:グローバル、データベース、テーブル、カラム。 |
RELOAD | FLUSH操作の使用を有効にします。レベル:グローバル。 |
REPLICATION CLIENT | ユーザーがマスターサーバーまたはスレーブサーバーの場所を確認できるようにします。レベル:グローバル。 |
REPLICATION SLAVE | 複製スレーブがバイナリログイベントをマスタから読み取るようにします。レベル:グローバル。 |
SELECT | の使用を有効にしますSELECT。レベル:グローバル、データベース、テーブル、カラム。 |
SHOW DATABASES | 有効SHOW DATABASESすべてのデータベースを表示します。レベル:グローバル。 |
SHOW VIEW | の使用を有効にしますSHOW CREATE VIEW。レベル:グローバル、データベース、テーブル。 |
SHUTDOWN | mysqladmin shutdownの使用を有効にします。レベル:グローバル。 |
SUPER | など、他の管理操作の使用を有効にし CHANGE MASTER TO、 KILL、 PURGE BINARY LOGS、 SET GLOBAL、およびmysqladminのデバッグコマンド。レベル:グローバル。 |
TRIGGER | トリガー操作を有効にします。レベル:グローバル、データベース、テーブル。 |
UPDATE | の使用を有効にしますUPDATE。レベル:グローバル、データベース、テーブル、カラム。 |
USAGE | 同義語「権限なし」 |
上記だけ権限が用意されております。
ユーザー確認
SELECT user, host FROM user;
+-----------+------+
| Host | User |
+-----------+------+
| 127.0.0.1 | root |
| localhost | ami |
| localhost | root |
+-----------+------+
3 rows in set (0.00 sec)
パスワード設定
password
set password for username@localhost=password('password');
作成したユーザーでログイン
mysql -u username -p
Enter password: #先ほど設定したパスワードでログイン