MYSQL搭建
mysql安裝部署
參考文件:
mysql安裝可以分為 1.rpm方式,2.tar壓縮包方式,兩者的差別rpm類似“一鍵安裝”模式,tar方式則是”高階定義“,企業中大多數為“高階定義”方式安裝。
rpm方式安裝
一:前提準備
1.檢測是否已經安裝
rpm -qa | grep mysql
2.檢測是否有mysql服務
ps -ef | grep mysql
3.檢測是否可連線外網
ping
4. 配置yum源
自帶的yum源可以滿足需要,如不滿足需自行配置
二:安裝步驟
1.搜尋到源,如果報錯可能是
網路
不通。
yum search mysql
2.線上安裝
yum install -y mysql-server.x86_64 --服務端
yum install -y mysql.x86_64 --客戶端
三:啟動服務
1.service mysqld start (備註: mysqld ‘D’表示後臺執行的程式)
2.檢視服務,埠號:
ps -ef | grep mysql
netstat -nls | grep 3306
備註:檢視到3306預設埠號即mysql服務啟動
四: 進入使用者
安裝好後悔預設建立root使用者,密碼為空
[root@hadoop001 ~]# mysql -uroot -p
Enter password: 直接回車 -
備註:生成採用互動式輸密碼,防止明文history命令將密碼明文。
tar方式安裝mysql包
企業裡專門的軟體會有專門的使用者去部署、執行
oa系統 oaadmin
erp系統 erpadmin
規範使用者可以規範許可權,易於管理
mysql 一個關係型資料庫被oracle收購,有免費版有收費版。
oracle
postgresql
sqlserver
id name age
1 ruoze 18
2 20
二:tar方式安裝
1.在聯網情況下可以網路直接下載安裝包
[root@sht-sgmhadoopnn-01 ~]# cd /usr/local
[root@sht-sgmhadoopnn-01 local]# wget
[root@sht-sgmhadoopnn-01 local]# wget .md5
--這裡我們用專用包下載
mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
2.本次安裝採用現成的
安裝包
進行安裝
secureCRT中輸入rz命令
1. root使用者進入目錄
[root@sht-sgmhadoopnn-01 ~]#
cd /usr/local
2.用md5檢測包的完整性。
[root@sht-sgmhadoopnn-01 local]# cat mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz.md5 --原始包中自帶的md5值
61affe944eff55fcf51b31e67f25dc10 mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
[root@sht-sgmhadoopnn-01 local]# md5sum mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
61affe944eff55fcf51b31e67f25dc10 mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
2. 檢測是否已經安裝
[root@sht-sgmhadoopnn-01 local]# ps -ef|grep mysqld
root 2493 2423 0 19:48 pts/3 00:00:00 grep mysqld
[root@sht-sgmhadoopnn-01 local]# rpm -qa |grep -i mysql
3.解壓包到指定目錄,然後重新命名
[
root
@sht-sgmhadoopnn-01 local] cd /usr/local
[root@sht-sgmhadoopnn-01 local] tar xzvf mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz --路徑是root使用者下/usr/local
[root@sht-sgmhadoopnn-01 local]# mv mysql-5.6.23-linux-glibc2.5-x86_64 mysql --
將解壓後的包重新命名為mysql(
因為之後的mysqladmin使用者家目錄是 /usr/loca/mysql,這樣在su - mysqladmin切換到家目錄後,直接進入解壓後的包目錄
,便於安
裝.)
4.建立使用者組
[root@sht-sgmhadoopnn-01 local]# groupadd -g 101 dba
[root@sht-sgmhadoopnn-01 local]# useradd -u 514 -g dba -G root -d /usr/local/mysql mysqladmin
useradd: warning: the home directory already exists. --如果使用者存在要當心了
Not copying any file from skel directory into it. --由於使用者已經存在會導致環境變數不會在家目錄中存在,坑!
## if user mysqladmin is existing,please execute the following command of usermod.
##[root@sht-sgmhadoopnn-01 local]# usermod -u 514 -g dba -G root -d /usr/local/mysql
[root@sht-sgmhadoopnn-01 local]# userdel mysqladmin --如使用者已存在則刪除
5.為使用者建立密碼
[root@sht-sgmhadoopnn-01 local]# id mysqladmin
uid=514(mysqladmin) gid=101(dba) groups=101(dba),0(root)
[root@sht-sgmhadoopnn-01 local]# passwd mysqladmin
6.複製環境變數.bash_profile等,如果ls -lart有,
此步驟可以省
略
## copy 環境變數配置檔案至mysqladmin使用者的home目錄中,為了以下步驟配置個人環境變數
[root@sht-sgmhadoopnn-01 local]# cp /etc/skel/.* /usr/local/mysql --將環境變數複製到mysqladmin家目錄下
cp: omitting directory `/etc/skel/.'
cp: omitting directory `/etc/skel/..'
cp: omitting directory `/etc/skel/.mozilla'
6.1配置環境變數
[mysqladmin@sht-sgmhadoopnn-01 ~]$ cat .bash_profile
# .bash_profile
# Get the aliases and functions
if [ -f ~/.bashrc ]; then
. ~/.bashrc
fi
# User specific environment and startup programs
export MYSQL_HOME=/usr/local/mysql
export PATH=${MYSQL_HOME}/bin:$PATH
export PATH
ps1=`uname -n`":"$USER":"$PWD":>"; --注意變數名要大寫
export PS1
#‘:’是分隔符,每次加環境變數要放到$PATH的前面(新變數放在前面是因為linux命令執行是按$PATH的先後順序查詢的,如果$PATH中已經包含老版本的變數值,優先尋找的還是老版本的環境變數),$PATH的意思原先的環境變數+新的變數
使變數生效
. .bash_profile
su - mysqladmin
複製環境變數後exit使用者
重新進入su - mysqladmin 可以看到當前游標處使用者路徑已經帶出來
7.配置mysql主配置檔案my.cnf (640許可權)
尋找配置檔案的順序
#defualt start: /etc/my.cnf->/etc/mysql/my.cnf->SYSCONFDIR/my.cnf->$MYSQL_HOME/my.cnf-> --defaults-extra-file->~/my.cnf
統一的我們在第一個位置配檔案
[root@sht-sgmhadoopnn-01 mysql]# cd /etc/ --在etc目錄下建立my.cnf
[root@sht-sgmhadoopnn-01 etc]# touch my.cnf
配置檔案內容:
[root@sht-sgmhadoopnn-01 etc]# vi my.cnf
[client] #客戶端配置位置
port = 3306
socket = /usr/local/mysql/data/mysql.sock
[mysqld] #服務端配置位置
port = 3306
socket = /usr/local/mysql/data/mysql.sock
skip-external-locking
key_buffer_size = 256M
sort_buffer_size = 2M
read_buffer_size = 2M
read_rnd_buffer_size = 4M
query_cache_size= 32M
max_allowed_packet = 16M
myisam_sort_buffer_size=128M
tmp_table_size=32M
table_open_cache = 512
thread_cache_size = 8
wait_timeout = 86400
interactive_timeout = 86400
max_connections = 600
# Try number of CPU's*2 for thread_concurrency
thread_concurrency = 32
#isolation level and default engine
default-storage-engine = INNODB
transaction-isolation = READ-COMMITTED
server-id = 1
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
pid-file = /usr/local/mysql/data/hostname.pid
#open performance schema
log-warnings
sysdate-is-now
binlog_format = MIXED
log_bin_trust_function_creators=1
log-error = /usr/local/mysql/data/hostname.err
log-bin=/usr/local/mysql/arch/mysql-bin
#other logs
#general_log =1
#general_log_file = /usr/local/mysql/data/general_log.err
#slow_query_log=1
#slow_query_log_file=/usr/local/mysql/data/slow_log.err
#for replication slave
#log-slave-updates
#sync_binlog = 1
#for innodb options
innodb_data_home_dir = /usr/local/mysql/data/ #存放資料目錄
innodb_data_file_path = ibdata1:500M:autoextend
innodb_log_group_home_dir = /usr/local/mysql/arch
innodb_log_files_in_group = 2
innodb_log_file_size = 200M
#生產上 機械硬碟
#sata盤 5000r 7200r(大眾生產) 10000r(大眾生產) 15000r 有條件用ssd
# innodb_buffer_pool_size 生產調優調大 8G
innodb_buffer_pool_size = 1024M #
free命令檢視伺服器記憶體,再適度分配
innodb_additional_mem_pool_size = 50M
innodb_log_buffer_size = 16M
innodb_lock_wait_timeout = 100
#innodb_thread_concurrency = 0
innodb_flush_log_at_trx_commit = 1
innodb_locks_unsafe_for_binlog=1
#innodb io features: add for mysql5.5.8
performance_schema
innodb_read_io_threads=4
innodb-write-io-threads=4
innodb-io-capacity=200
#purge threads change default(0) to 1 for purge
innodb_purge_threads=1
innodb_use_native_aio=on
#case-sensitive file names and separate tablespace
innodb_file_per_table = 1
lower_case_table_names=1
[mysqldump]
quick
max_allowed_packet = 16M #
最大資料包
[mysql]
no-auto-rehash
[mysqlhotcopy]
interactive-timeout
[myisamchk]
key_buffer_size = 256M
sort_buffer_size = 256M
read_buffer = 2M
write_buffer = 2M
---------------------------
8.更改my.cnf許可權
[root@sht-sgmhadoopnn-01 local]# chown mysqladmin:dba /etc/my.cnf
[root@sht-sgmhadoopnn-01 local]# chmod
640
/etc/my.cnf
[root@sht-sgmhadoopnn-01 etc]# ll my.cnf
-rw-r----- 1
mysqladmin dba
2201 Aug 25 23:09 my.cnf
9.更改家目錄下使用者、組的許可權
[root@sht-sgmhadoopnn-01 local]# chown -R mysqladmin:dba /usr/local/mysql
[root@sht-sgmhadoopnn-01 local]# chmod -R 755 /usr/local/mysql
10. 切換到mysql家目錄,並建立arch目錄,arch目錄是在my.cnf指定的
root@sht-sgmhadoopnn-01 local]# su - mysqladmin
[mysqladmin@sht-sgmhadoopnn-01 ~]$ pwd
/usr/local/mysql
建立arch目錄用來儲存binlog二進位制歸檔日誌 mysql--maxwell--kafka--sparkstrm--hbase 實時
cd /usr/local/mysql
mkdir arch
11.開始安裝,用家目錄下的指令碼
[mysqladmin@sht-sgmhadoopnn-01 ~]$ scripts/mysql_install_db
Installing MySQL system tables..../bin/mysqld:
error while loading shared libraries: libaio.so.1: cannot open shared object file:
No such file or directory #缺少libaio.so 包
====================
缺少包解決方法
:
1.檢視版本
[root@sht-sgmhadoopnn-01 local]# cat /proc/version
Linux version 2.6.18-164.11.1.el5 (mockbuild@builder10.centos.org) (gcc version 4.1.2 20080704 (Red Hat 4.1.2-46)) #1 SMP Wed Jan 20 07:32:21 EST 2010
2.檢視是否有gcc包
[root@sht-sgmhadoopnn-01 local]# rpm -qa |grep gcc
libgcc-4.1.2-46.el5_4.2
libgcc-4.1.2-46.el5_4.2
3.安裝對應包
[root@sht-sgmhadoopnn-01 local]# yum -y install libaio
假設前面安裝錯誤再次安裝,需要清空兩個目錄遺留檔案:
rm -rf data/*
rm -rf arch/*
=====================
12.開始安裝,為保險起見,指定了執行路徑,實在是不用指定的。
[mysqladmin@sht-sgmhadoopnn-01 ~]$ scripts/mysql_install_db \
--user=mysqladmin \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
檢視data/hostname.err檔案 仔細錯誤
或者:
scripts/mysql_install_db \
--user=mysqladmin \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data \
--defaults-file=/etc/my.cnf --手工指定defaults-file方法
或者:
[root@bogon scripts]# /usr/local/mysql/scripts/mysql_install_db --user=mysqladmin --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data &
備註:因為mysql家目錄為/usr/local/mysql,而我們上面步驟已經將tar包更名為mysql,在su - mysqladmin切換到家目錄時,已經進入tar解壓後的安裝包,此時可以看到script目錄
13.配置mysql開機自啟
[root@sht-sgmhadoopnn-01 ~]# cd /usr/local/mysql
#將服務檔案複製到init.d下,並重新命名為mysql
[root@sht-sgmhadoopnn-01 mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysql
#賦予可執行許可權
[root@sht-sgmhadoopnn-01 mysql]# chmod +x /etc/rc.d/init.d/mysql
#刪除服務
[root@sht-sgmhadoopnn-01 mysql]# chkconfig --del mysql
#重新新增服務
[root@sht-sgmhadoopnn-01 mysql]# chkconfig --add mysql
#新增開機啟動服務
[root@sht-sgmhadoopnn-01 mysql]# chkconfig --level 345 mysql on
[root@sht-sgmhadoopnn-01 mysql]# vi /etc/rc.local
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.
touch /var/lock/subsys/local
su - mysqladmin -c "/etc/init.d/mysql start --federated"
---------------
[root@hadoop ~]# cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysql
[root@hadoop ~]# chmod +x /etc/rc.d
rc.d/ rc.local rc.sysinit
[root@hadoop ~]# chmod +x /etc/rc.d/init.d/mysql
[root@hadoop ~]# ll /etc/rc.d/init.d/mysql
-rwxr-xr-x 1 root root 10880 Jan 29 12:47 /etc/rc.d/init.d/mysql
---------------
9. 啟動mysql
[root@sht-sgmhadoopnn-01 mysql]# su - mysqladmin
[mysqladmin@sht-sgmhadoopnn-01 ~]$ pwd
/usr/local/mysql
[mysqladmin@sht-sgmhadoopnn-01 ~]$ rm -rf my.cnf #保留也可以,因為目錄下已經有了
[mysqladmin@hadoop001 ~]$ service mysql start #開啟服務
Starting MySQL. [ OK ]
[mysqladmin@hadoop001 ~]$ service mysql status
MySQL running (3625) [ OK ]
或者:
#另一種安全模式啟動,同樣是可以的
[mysqladmin@sht-sgmhadoopnn-01 ~]$ mysqld_safe & #安全模式開啟,另一種開啟方式,執行後游標處回車
[1] 11802
[mysqladmin@sht-sgmhadoopnn-01 ~]$ 150825 22:53:38 mysqld_safe Logging to '/usr/local/mysql/data/hostname.err'.
150825 22:53:38 mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data/
150825 22:53:39 mysqld_safe mysqld from pid file /usr/local/mysql/data/hostname.pid ended
[mysqladmin@sht-sgmhadoopnn-01 ~]$ which mysqld_safe
~/bin/mysqld_safe #可以看到mysqld_safe的目錄
10. 檢視服務監聽
[mysqladmin@sht-sgmhadoopnn-01 ~]$ ps -ef|grep
mysqld --是mysqld不是mysql
514 6247 6219 0 17:30 pts/1 00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe
514 6902 6247 2 17:30 pts/1 00:00:01 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --log-error=/usr/local/mysql/data/hostname.err --pid-file=/usr/local/mysql/data/hostname.pid --socket=/usr/local/mysql/data/mysql.sock --port=3306 #
3306說明已經啟動
514 6927 6219 0 17:31 pts/1 00:00:00 grep mysqld
檢視監聽
[mysqladmin@sht-sgmhadoopnn-01 ~]$ netstat -tulnp | grep mysql #檢視埠
(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)
tcp 0 0 :::3306 :::* LISTEN 11541/mysqld
[root@sht-sgmhadoopnn-01 local]# service mysql status
MySQL running (21507) [ OK ]
至此部署完成
備註:
mysql會建立兩個使用者
1.root使用者 密碼為空
要更改密碼
2.空使用者 密碼為空
要刪除該使用者
登入方式:
#注意事項1.不用明密碼登入。2.-p等引數不能加空格
bin/mysql -uroot -p -h127.0.0.1 #回車輸入密碼 此方式安全不會被history記錄
bin/mysql -uroot -p123456 -h127.0.0.1 #此方式不安全的 會被history記錄
bin/mysql -u root -p 123456 -h 127.0.0.1 -P3306 #加埠號方式,此方式不安全,127.0.0.1是自己的電腦ip
11. 登入mysql
[mysqladmin@sht-sgmhadoopnn-01 ~]$ bin/mysql -uroot -p
也可以進入/usr/local/mysql/bin目錄,./mysql -uroot -p表示執行當前路徑下的mysql ./是相對路徑 。
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
4 rows in set (0.00 sec)
12.更改root密碼,刪除空使用者
mysql> use mysql
Database changed
安全起見要做兩件事
1.更改root的密碼不為空
2.刪除空使用者
mysql> update user set password=password('123456') where user='root'; #
將root使用者更改密碼
,passwodr('123456')是加密
Query OK, 4 rows affected (0.00 sec)
Rows matched: 4 Changed: 4 Warnings: 0
mysql> select host,user,password from user;
+----------------+------+-------------------------------------------+
| host | user | password |
+----------------+------+-------------------------------------------+
| localhost | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| sht-sgmhadoopnn-01 | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| 127.0.0.1 | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| ::1 | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| localhost | | |
| sht-sgmhadoopnn-01 | | |
+----------------+------+-------------------------------------------+
6 rows in set (0.00 sec)
mysql> delete from user where user=''; #
刪除空使用者
mysql> select host,user,password from user;
+----------------+------+-------------------------------------------+
| host | user | password |
+----------------+------+-------------------------------------------+
| localhost | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| sht-sgmhadoopnn-01 | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| 127.0.0.1 | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
| ::1 | root | *6340BE3C15D246B0D74BAF3F135915ED19E0069F |
+----------------+------+-------------------------------------------+
4 rows in set (0.00 sec)
#針對使用者 許可權的操作語句最後一步執行重新整理許可權
mysql> flush privileges;
13.重新登入
bin/mysql -uroot -p -hlocalhost
14.Configure .bash_profile #配置環境變數
[mysqladmin@sht-sgmhadoopnn-01 ~]$ cat .bash_profile
# .bash_profile
# Get the aliases and functions
if [ -f ~/.bashrc ]; then
. ~/.bashrc
fi
# User specific environment and startup programs
export MYSQL_HOME=/usr/local/mysql
export PATH=${MYSQL_HOME}/bin:$PATH
export PATH
ps1=`uname -n`":"$USER":"$PWD":>"; --注意變數名要大寫
export PS1
#‘:’是分隔符,每次加環境變數要放到$PATH的前面(新變數放在前面是因為linux命令執行是按$PATH的先後順序查詢的,如果$PATH中已經包含老版本的變數值,優先尋找的還是老版本的環境變數),$PATH的意思原先的環境變數+新的變數
使變數生效
. .bash_profile
su - mysqladmin
-----------------------------------
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28339956/viewspace-2621326/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- docker 搭建 MySQLDockerMySql
- mysql主從搭建MySql
- mysql叢集搭建MySql
- MySQL叢集搭建(1)-主備搭建MySql
- mysql8.0.31 mgr搭建MySql
- OrbStack搭建Mysql服務ORBMySql
- MySQL MGR 叢集搭建MySql
- docker搭建mysql叢集DockerMySql
- MySQL 5.7 叢集搭建MySql
- MYSQL主從搭建5.6.38MySql
- Mysql主從搭建(docker compose)MySqlDocker
- CentOS 下 MySQL 服務搭建CentOSMySql
- mysql8叢集搭建MySql
- MySQL環境搭建利器---SandboxMySql
- MySQL叢集搭建方案(PXC)MySql
- 搭建Lepus 天兔 監控MySQLMySql
- mysql負載均衡搭建(haproxy)MySql負載
- mysql高可用衡搭建(Keepalived)MySql
- mysql主從複製搭建MySql
- Docker 方式 MySQL 主從搭建DockerMySql
- Linux中Mysql的叢集搭建LinuxMySql
- 華為高斯DB(for MySQL)搭建演示MySql
- MySQL MHA詳細搭建過程MySql
- 搭建node服務(二):操作MySQLMySql
- 基於GTID搭建主從MySQLMySql
- mysql高可用架構MHA搭建MySql架構
- mac下搭建nginx+php+mysqlMacNginxPHPMySql
- mysql雙主雙從 搭建配置MySql
- mysql高可用架構MHA搭建(centos7+mysql5.7.28)MySql架構CentOS
- 【MySQL】MySQL Replication 一主一備搭建步驟(GTID方式)MySql
- MYSQL5.6.40原始碼安裝 主從搭建 主主搭建MySql原始碼
- 簡單搭建MySQL主從複製MySql
- Mysql主從複製原理及搭建MySql
- MySQL MGR 叢集搭建(單主模式)MySql模式
- 記一次 MySQL 主從搭建MySql
- 在容器環境搭建mysql備庫MySql
- MySql雙主一從服務搭建MySql
- Linux搭建PHP+MySQL+Apache環境LinuxPHPMySqlApache