首页 > 代码库 > mysql-5.5.56版本(二进制包安装)-自定义安装路径

mysql-5.5.56版本(二进制包安装)-自定义安装路径

mysql-5.5.56版本(二进制包安装)-自定义安装路径

安装路径:/application/mysql-5.5.56

1.前期准备

mysql依赖

libaio

yum install -y libaio


创建用户mysql,以该用户的身份执行mysql

useradd -s /bin/false -M mysql


下载mysql二进制包并解压

cd /tools
wget https://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.56-linux-glibc2.5-x86_64.tar.gz
tar -zxf mysql-5.5.56-linux-glibc2.5-x86_64.tar.gz -C /application/


切换到/application目录,将mysql文件夹名改短,给mysql目录做一个软链接

cd /application/
mv mysql-5.5.56-linux-glibc2.5-x86_64/ mysql-5.5.56
ln -s mysql-5.5.56/ mysql


递归设置mysql目录的所属组和所属用户

chown -R mysql:mysql mysql-5.5.56/


 

2.mysql目录内操作

cd mysql


初始化数据库

会在mysql目录内生成一个data目录,存放数据库的目录

./scripts/mysql_install_db --basedir=/application/mysql --datadir=/application/mysql/data/ --user=mysql


更改所属用户和组

chown -R root .
chown -R mysql data


除了mysql目录下的data目录所属用户不变,其他所有文件的所属用户改为root

拷贝配置文件

cp support-files/my-medium.cnf /etc/my.cnf


mysql的配置文件拷贝为/etc/目录下的my.cnf

修改配置文件

sed -i 28i‘log-error=/application/mysql/data/mysqld.error‘ /etc/my.cnf


在配置文件插入了一行,进行配置错误日志

/etc/my.cnf Content:

# Example MySQL config file for medium systems.
#
# This is for a system with little memory (32M - 64M) where MySQL plays
# an important part, or systems up to 128M where MySQL is used together with
# other programs (such as a web server)
#
# MySQL programs look for option files in a set of
# locations which depend on the deployment platform.
# You can copy this option file to one of those
# locations. For information about these locations, see:
# http://dev.mysql.com/doc/mysql/en/option-files.html
#
# In this file, you can use all long options that a program supports.
# If you want to know which options a program supports, run the program
# with the "--help" option.
 
# The following options will be passed to all MySQL clients
[client]
#password       = your_password
port            = 3306
socket          = /tmp/mysql.sock
 
# Here follows entries for some specific programs
 
# The MySQL server
[mysqld]
port            = 3306
log-error=/application/mysql/data/mysqld.error
socket          = /tmp/mysql.sock
skip-external-locking
key_buffer_size = 16M
max_allowed_packet = 1M
table_open_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
 
# Don‘t listen on a TCP/IP port at all. This can be a security enhancement,
# if all processes that need to connect to mysqld run on the same host.
# All interaction with mysqld must be made via Unix sockets or named pipes.
# Note that using this option without enabling named pipes on Windows
# (via the "enable-named-pipe" option) will render mysqld useless!
#
#skip-networking
 
# Replication Master Server (default)
# binary logging is required for replication
log-bin=mysql-bin
 
# binary logging format - mixed recommended
binlog_format=mixed
 
# required unique id between 1 and 2^32 - 1
# defaults to 1 if master-host is not set
# but will not function as a master if omitted
server-id       = 1
 
# Replication Slave (comment out master section to use this)
#
# To configure this host as a replication slave, you can choose between
# two methods :
#
# 1) Use the CHANGE MASTER TO command (fully described in our manual) -
#    the syntax is:
#
#    CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>,
#    MASTER_USER=<user>, MASTER_PASSWORD=<password> ;
#
#    where you replace <host>, <user>, <password> by quoted strings and
#    <port> by the master‘s port number (3306 by default).
#
#    Example:
#
#    CHANGE MASTER TO MASTER_HOST=‘125.564.12.1‘, MASTER_PORT=3306,
#    MASTER_USER=‘joe‘, MASTER_PASSWORD=‘secret‘;
#
# OR
#
# 2) Set the variables below. However, in case you choose this method, then
#    start replication for the first time (even unsuccessfully, for example
#    if you mistyped the password in master-password and the slave fails to
#    connect), the slave will create a master.info file, and any later
#    change in this file to the variables‘ values below will be ignored and
#    overridden by the content of the master.info file, unless you shutdown
#    the slave server, delete master.info and restart the slaver server.
#    For that reason, you may want to leave the lines below untouched
#    (commented) and instead use CHANGE MASTER TO (see above)
#
# required unique id between 2 and 2^32 - 1
# (and different from the master)
# defaults to 2 if master-host is set
# but will not function as a slave if omitted
#server-id       = 2
#
# The replication master for this slave - required
#master-host     =   <hostname>
#
# The username the slave will use for authentication when connecting
# to the master - required
#master-user     =   <username>
#
# The password the slave will authenticate with when connecting to
# the master - required
#master-password =   <password>
#
# The port the master is listening on.
# optional - defaults to 3306
#master-port     =  <port>
#
# binary logging - not required for slaves, but recommended
#log-bin=mysql-bin
 
# Uncomment the following if you are using InnoDB tables
#innodb_data_home_dir = /usr/local/mysql/data
#innodb_data_file_path = ibdata1:10M:autoextend
#innodb_log_group_home_dir = /usr/local/mysql/data
# You can set .._buffer_pool_size up to 50 - 80 %
# of RAM but beware of setting memory usage too high
#innodb_buffer_pool_size = 16M
#innodb_additional_mem_pool_size = 2M
# Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 5M
#innodb_log_buffer_size = 8M
#innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50
 
[mysqldump]
quick
max_allowed_packet = 16M
 
[mysql]
no-auto-rehash
# Remove the next comment character if you are not familiar with SQL
#safe-updates
 
[myisamchk]
key_buffer_size = 20M
sort_buffer_size = 20M
read_buffer = 2M
write_buffer = 2M
 
[mysqlhotcopy]
interactive-timeout


拷贝启动程序

cp support-files/mysql.server /etc/init.d/mysql


mysql的启动程序拷贝到/etc/init.d/目录下,以便启动程序

编辑启动文件,配置启动目录

方法一:

思路是给配置文件提供的变量进行赋值。较麻烦。

sed -i ‘:a;N;$!ba;s/basedir=\ndatadir=/basedir=\/application\/mysql\ndatadir=\/application\/mysql\/data/g‘ /etc/init.d/mysql
sed -i ‘:a;N;$!ba;s/mysqld_pid_file_path=\n/mysqld_pid_file_path=\/application\/mysql\/data\/mysqld.pid\n/g‘ /etc/init.d/mysql


等价于将4546两行

basedir=
datadir=
mysqld_pid_file_path=
替换成
basedir=/application/mysql
datadir=/application/mysql/data
mysqld_pid_file_path=/application/mysql/data/mysql.pid


 

方法二(推荐):

思路是将脚本的默认地址(/usr/local/mysql)直接替换成自定义路径(/application/mysql),便不用给变量赋值

sed -i ‘s#/usr/local/mysql#/application/mysql#g‘ /etc/init.d/mysql


 

到这里mysql安装完成可以正常启动

 

 

3.后期结尾

命令创建软链接

mysql命令创建软链接到环境变量的目录,使用户可以在变量找到相应的命令

ln -s /application/mysql/bin/* /usr/local/sbin


设置与修改密码

第一次设置密码:

mysqladmin -u‘<User>‘ password ‘<PassWord>‘


例子:

mysqladmin -u‘root‘ password ‘PassWord‘


 

往后修改密码:

mysqladmin -u‘<User>‘ -p‘<OldPassWord>‘ password ‘<NewPassWord>‘


例子:

mysqladmin -u‘root‘ -p‘PassWord‘ password ‘NewPassWord‘


登录mysql

[root@www mysql]# mysql -u‘root‘ -p‘PassWord‘
Welcome to the MySQL monitor.  Commands end with ; or \g.
...
mysql>  #成功登陆到mysql控制台
 
 
[root@www mysql]# mysql -uroot -pPassWord
Welcome to the MySQL monitor.  Commands end with ; or \g.
...
mysql>  #成功登陆到mysql控制台
 
 
[root@www mysql]# mysql -u‘root‘ -p
Enter password:  #这里输入用户的密码
Welcome to the MySQL monitor.  Commands end with ; or \g.
...
mysql>  #成功登陆到mysql控制台
 
 
[root@www mysql]# mysql -uroot -p
Enter password:  #这里输入用户的密码
Welcome to the MySQL monitor.  Commands end with ; or \g.
...
mysql>  #成功登陆到mysql控制台


键入quit或Ctrl + d退出mysql环境

mysql> quit
Bye
[root@www mysql]#
or
mysql> ^DBye
[root@www mysql]#


 

 

4.常用命令

进入mysql

mysql -u‘root‘ -p‘PassWord‘
mysql -uroot -pPassWord
 
mysql -u‘root‘ -p
mysql -uroot -p


启动mysql

service mysql start


停止mysql

service mysql stop


重启mysql

service mysql restart


 


本文出自 “这就是你的选择 | CzlunSu” 博客,请务必保留此出处http://czlun.blog.51cto.com/9876583/1945878

mysql-5.5.56版本(二进制包安装)-自定义安装路径