LoginSignup
0
0

More than 5 years have passed since last update.

MYSQL5.1* インサートからユーザー追加

Last updated at Posted at 2017-09-02

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:  #先ほど設定したパスワードでログイン
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0