一、环境
- CentOS6.5
二、软件版本
- mysql-5.6.23下载地址
三、安装步骤
- 软件上传和解压
- 用户和用户组创建
- 软件安装和配置
- 验证安装
四、安装过程
1. 软件上传和解压(注意命令执行时候的目录)
1.1 在CentOS中安装上传下载软lrzsz
执行命令
[root@hadoop-002 ~]# cd /usr/local/
[root@hadoop-002 local]# yum -y install lrzsz
1.2 文件上传
安装完lrzsz之后执行命令
[root@hadoop-002 local]# rz
弹出文件选择框,选择需要安装的mysql软件包
001.png
之后点击OK,文件开始上传。
1.3 检查mysql是否已经安装
执行命令
[root@hadoop-002 local]# ps -ef|grep mysql
如果已经安装且需要卸载,执行命令
[root@hadoop-002 local]# rpm -qa |grep -i mysql
1.4 解压文件
执行命令
[root@hadoop-002 local]# tar xzvf mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
解压完成后,将解压目录移动到mysql目录下,执行命令:
[root@hadoop-002 local]# mv mysql-5.6.23-linux-glibc2.5-x86_64 mysql
2. 用户和用户组创建
单独为mysql创建一个用户和用户组。(具体原因后续补充)
2.1 用户组创建
执行命令
[root@hadoop-002 local]# groupadd -g 101 dba
2.2 用户创建,并指定用户的主目录和用户组
执行命令
[root@hadoop-002 local]# useradd -u 514 -g dba -G root -d /usr/local/mysql mysqladmin
验证用户的用户组
执行命令
[root@hadoop-002 local]# id mysqladmin
为用户mysqladmin设置密码
执行命令
[root@hadoop-002 local]# passwd mysqladmin
连续输入两次密码,完成。
3. 软件安装和配置
3.1 为mysqladmin用户创建个人配置
执行命令,拷贝个人配置文件到/usr/local/mysql目录下
[root@hadoop-002 local]# cp /etc/skel/.* /usr/local/mysql
3.2 创建mysql的配置文件
执行命令
[root@hadoop-002 local]# vi /etc/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
innodb_buffer_pool_size = 2048M
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
3.3 配置权限
修改mysql配置文件的所属用户,执行命令
[root@hadoop-002 local]# chown mysqladmin:dba /etc/my.cnf
修改mysql配置文件的权限,执行命令
[root@hadoop-002 local]# chmod 640 /etc/my.cnf
查看结果,执行命令:
[root@hadoop-002 local]# ll /etc/my.cnf
结果如下
-rw-r-----. 1 mysqladmin dba 2218 5月 15 07:42 /etc/my.cnf
修改mysql目录所属用户,执行命令
[root@hadoop-002 local]# chown -R mysqladmin:dba /usr/local/mysql
修改mysql目录权限,执行命令
[root@hadoop-002 local]# chmod -R 755 /usr/local/mysql
3.4 安装软件
切换到mysqladmin用户,执行命令
[root@hadoop-002 local]# su - mysqladmin
创建arch目录,执行命令(暂时不知道为什么要创建这个)
[mysqladmin@hadoop-002 ~]$ mkdir arch
第一次安装,执行命令:
[mysqladmin@hadoop-002 ~]$ scripts/mysql_install_db --user=mysqladmin --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
没有出现error则安装成功。
3.5 配置mysql服务
切换到root用户,执行命令
[mysqladmin@hadoop-002 ~]$ su - root
进入mysql目录,执行命令
[root@hadoop-002 ~]# cd /usr/local/mysql
将服务文件拷贝到init.d下,并重命名为mysql,执行命令
[root@hadoop-002 mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysql
赋予可执行权限,执行命令
[root@hadoop-002 mysql]# chmod +x /etc/rc.d/init.d/mysql
删除服务,执行命令
[root@hadoop-002 mysql]# chkconfig --del mysql
添加服务,执行命令
[root@hadoop-002 mysql]# chkconfig --add mysql
修改服务的默认启动等级,执行命令
[root@hadoop-002 mysql]# chkconfig --level 345 mysql on
启动等级说明:
等级0表示:表示关机
等级1表示:单用户模式
等级2表示:无网络连接的多用户命令行模式
等级3表示:有网络连接的多用户命令行模式
等级4表示:不可用
等级5表示:带图形界面的多用户模式
等级6表示:重新启动
需要说明的是,level选项可以指定要查看的运行级而不一定是当前运行级。对于每个运行级,只能有一个启动脚本或者停止脚本。当切换运行级时,init不会重新启动已经启动的服务,也不会再次去停止已经停止的服务。
3.6 启动mysql服务
切换到mysql用户,执行命令
[root@hadoop-002 mysql]# su - mysqladmin
删除多余配置文件,执行命令
[mysqladmin@hadoop-002 ~]$ rm -rf my.cnf
启动mysql,执行命令
[mysqladmin@hadoop-002 ~]$ bin/mysqld_safe &
验证服务是否启动,依次执行命令
[mysqladmin@hadoop-002 ~]$ ps -ef|grep mysqld
[mysqladmin@hadoop-002 ~]$ ps -ef|grep mysqld
[mysqladmin@hadoop-002 ~]$ service mysql status
修改个人环境变量,将mysql环境变量写入配置文件中,执行命令
[mysqladmin@hadoop-002 ~]$ vi .bash_profile
修改后配置文件如下:
# .bash_profile
# Get the aliases and functions
if [ -f ~/.bashrc ]; then
. ~/.bashrc
fi
# User specific environment and startup programs
MYSQL_BASE=/usr/local/mysql
export MYSQL_BASE
PATH=$PATH:${MYSQL_BASE}/bin:/usr/kerberos/bin:/opt/bin:/bin:/usr/bin:/usr/local/bin:/usr/bin/X11:/usr/X11R6/bin:/usr/local/mysql
export PATH
PS1=`uname -n`":"'$USER'":"'$PWD'":>"; export PS1
alias l="ls -ltr"
alias la="ls -la"
alias d="df -lk"
#alias rm="rm -i"
alias bg="ps -aef|grep mysql"
alias base="cd /usr/local/mysql"
alias bin="cd //usr/local/mysql/bin"
alias dba="cd /usr/local/mysql/dba"
alias sh="cd /usr/local/mysql/dba/sh"
alias sql="cd /usr/local/mysql/dba/sql"
alias config="cd /usr/local/mysql/dba/config"
alias dbalog="cd /usr/local/mysql/dba/log"
alias arch="cd /usr/local/mysql/arch"
alias data="cd /usr/local/mysql/data"
## endendend
网友评论