Mysql安装脚本

Mysql

PS:要先看懂脚本在复制粘贴运行脚本,每个人的环境不一样

#/bin/bash 
#--------变量
#num=`expr $RANDOM % 5 + 1`
now_lujing=`pwd`

#-------------------------配置用户文件函数
function user_file_config()
{
#下载Mysql
  wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.31.tar.gz #
-----------------------------------添加组,用户 groupadd mysql &>/dev/null useradd mysql -g mysql -s /sbin/nologin #-----------------------------------建立必要文件 #Mysql的安装目录 mkdir -p /usr/local/mysql #Mysql数据目录 mkdir -p /data/mysqldb #创建BINLOG日志目录 mkdir -p /data/mysqldb/binlog #创建MYSQL 日常LOG目录 mkdir -p /data/mysqldb/log #数据库临时目录 mkdir /opt/mysqltmp #解压编译mysql源码 make_mysql; #给Mysql安装目录进行授权 chown mysql:mysql /usr/local/mysql -R #---------------------------------更改权限 chown mysql:mysql /opt/mysqltmp #-给Mysql数据存储目录进行授权 chown mysql:mysql /data/mysqldb -R #-给Mysl日志目录进行授权 chown mysql:mysql /data/mysqldb/binlog/ chown mysql:mysql /data/mysqldb/log/ #开始初始化 #复制配置文件 echo y|cp $now_lujing/my.cnf /etc/my.cnf #指定使用者,user,运行目录/usr/local/mysql 制定数据存放文件 /data/mysqldb /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysqldb #拷贝命令到init.d文件里面去 cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld chmod 755 /etc/init.d/mysqld #启动服务和设置环境变量 #:vim /etc/profile #文件的最后面。 echo -e "MYSQL=/usr/local/mysql/bin \nPATH=\$PATH:\$MYSQL\nexport PATH" >>/etc/profile #生效 source /etc/profile } function make_mysql() { if [ ! -d mysql-5.6.31 ] then tar -xvf mysql-5.6.31.tar.gz fi cd mysql-5.6.31 cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ -DSYSCONFDIR=/etc \ -DDEFAULT_CHARSET=gbk \ -DDEFAULT_COLLATION=gbk_chinese_ci \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITH_FEDERATED_STORAGE_ENGINE=1 \ -DWITH_PARTITION_STORAGE_ENGINE=1 \ -DMYSQL_DATADIR=/data/mysqldb \ -DMYSQL_TCP_PORT=3306 make && make install } #-------检查yum源有没有配置成功 function check_yum() { yum clean all &>/dev/null yum repolist &> /tmp/repolist.los rpm_num=`cat /tmp/repolist.los|grep repolist|awk '{print $2}'` # echo $rpm_num if [ "$rpm_num" == "0" ] then echo error:`date +%F-%R`yum源没有配置好 >>mysql_log else echo error:`date +%F-%R`yum源配置好了 >>mysql_log yum install gcc gcc-c++ ncurses-devel perl camke bison cmake -y [ $? -eq 0 ] && echo -e succed:"`date +%F-%R`\tmysql所需要的依赖包已经成功安装 >>mysql_log" || echo -e filed:"`date +%F-%R`\tmysql所需要的依赖包没有安装成功 >>mysql_log" fi } function main() { check_yum; user_file_config #启动服务 /etc/init.d/mysqld start } main;

 

my.cnf

[client]
port = 3306
socket = /tmp/mysql.sock

[mysqld]

#base
port = 3306
user = mysql
socket = /tmp/mysql.sock
pid-file = /tmp/mysql.pid
basedir = /usr/local/mysql
datadir = /data/mysqldb
tmpdir = /opt/mysqltmp
open_files_limit = 10240
explicit_defaults_for_timestamp
sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
federated 

server_id = 706
#replicate-do-db = posp
#replicate-ignore-db = mysql
#log-slave-updates = 1
event_scheduler=1 

max_connections = 2000
max_connect_errors = 10000
interactive_timeout = 600
wait_timeout = 600
skip-name-resolve
sync_binlog=0
log_bin_trust_function_creators = 1

character-set-server = utf8
default_storage_engine = InnoDB

#log
log-bin = /data/mysqldb/binlog/mysql-bin
binlog_cache_size = 32m
max_binlog_cache_size = 10g
binlog_stmt_cache_size = 32m
table_open_cache = 2048
max_binlog_size = 1024m
binlog_format = mixed
log_output = FILE
log-error = /data/mysqldb/log/mysql-error.log
slow_query_log = 1
slow_query_log_file = /data/mysqldb/log/mysql-slow_query.log
general_log = 0
general_log_file = /data/mysqldb/log/mysql-general-query.log
expire-logs-days = 30
relay-log = /data/mysqldb/binlog/relay-bin
relay-log-index= /data/mysqldb/binlog/relay-bin.index

#buffer
sort_buffer_size = 2m 
read_buffer_size = 2m
read_rnd_buffer_size = 2m
join_buffer_size = 2m

net_buffer_length = 16k
max_allowed_packet = 512m
bulk_insert_buffer_size = 32m
max_heap_table_size = 512m
tmp_table_size = 512m
thread_cache_size = 100
query_cache_size = 256m
query_cache_limit = 10m
query_cache_min_res_unit = 4k
key_buffer_size = 16m
myisam_sort_buffer_size = 64m
myisam_max_sort_file_size = 10g
myisam_repair_threads = 1

#innodb
innodb_file_per_table = 1
innodb_data_file_path = ibdata1:2048M:autoextend
innodb_log_file_size = 128m
innodb_log_files_in_group = 3
innodb_buffer_pool_size = 1g
innodb_buffer_pool_instances = -1
innodb_max_dirty_pages_pct = 70
#innodb_thread_concurrency = 8
innodb_flush_method = O_DIRECT
innodb_log_buffer_size = 16m
innodb_flush_log_at_trx_commit = 2

[mysql]
no-auto-rehash
prompt = (\u@\h) [\d]\_
default-character-set = utf8

 

posted on 2016-09-03 02:04  losbyday  阅读(820)  评论(0编辑  收藏  举报

导航