首页 > 数据库 >linux一键安装MySQL的脚本,保姆级别的脚本注释,你肯定能看懂

linux一键安装MySQL的脚本,保姆级别的脚本注释,你肯定能看懂

时间:2024-09-05 14:52:41浏览次数:15  
标签:脚本 grep mysql linux cnf etc export MySQL my

1,下载官方安装包

首先下载MySQL的官方安装包

2,上传安装包到 /opt/

  • /opt//mysql-8.0/mysql-8.0.13-linux-glibc2.12-x86_64.tar.xz

3,复制以下代码

  • 保存到/opt/mysql_install.sh里面去
  • (你需要相对应修改的地方就是设置MySQL用户密码那里,在第22行23行那里,其他不用动)
  • 然后赋予可执行权限给这个脚本,最后运行这个脚本

4,安装完成

  • 试试吧,失败的小伙伴可以评论我给你解决一下。按道理应该不会出错
#!/bin/bash#
# 要用root用户 ##


#获取本机的ip地址,然后将这个ip地址设置为环境变量ipaddr的值 
export ipaddr=`ip a | grep -w inet | grep -v 127| awk '{ print $2 }' |awk -F '/' '{print $1}'`
#将本机的ip地址的第三第四位合在一起,然后赋予给环境变量serverid,加入本机ip为10.192.168.178,那么serverid=168178
export serverid=`echo $ipaddr | awk -F '.' '{print $3$4}'`

#以下这一段是为了求得机器的内存是多少。dmidecode -t 17是获取系统内存相关信息,并把这个值赋予给MEM_SIZE这个环境变量
export UNIT=`dmidecode -t 17|grep -i size |grep -i GB|wc -l`
if [[ $UNIT -eq 0 ]]; then
export MEM_SIZE=`dmidecode -t 17|grep -i size |grep -v 'No'|awk '{sum+=$2;}END{print sum;}'`
else
export SIZE=`dmidecode -t 17|grep -i size |grep -v 'No'|awk '{sum+=$2;}END{print sum;}'`
export MEM_SIZE=$(($SIZE*1024))
fi

# 物理内存等于虚拟内存除以2,并把这个值赋予给buffer这个环境变量
export buffer=$(($MEM_SIZE/2))
# 密码需要修改
export pwd=yourpassword
export rplpwd=yourpassword
#统计一下 系统中装有mariadb-libs的数量
mariadbcheck=`rpm -qa|grep mariadb-libs|wc -l`
#如果统计值后发现mariadb-libs的数量等于1,说明系统里装了mariadb-libs,那么我就要用yum remove删除他
if [[ $mariadbcheck -eq 1 ]]; then
yum remove -y mariadb-libs
fi

#解压/opt 目录下的 mysql-8.0.13-linux-glibc2.12-x86_64.tar.xz 文件,并将解压过程中的输出信息重定向到 /dev/null ,这意味着不会在终端显示解压的详细过程和输出。
#tar 是用于打包和解包文件的命令。-J 表示使用 xz 格式进行解压缩。-x 表示解包。-v 表示显示详细信息。-f 后跟要操作的文件。
tar -Jxvf /opt/mysql-8.0.13-linux-glibc2.12-x86_64.tar.xz >/dev/null
mv /opt/mysql-8.0.13-linux-glibc2.12-x86_64/* /usr/local/mysql/
chown -R mysql:mysql /usr/local/mysql/
cp /usr/local/mysql/bin/* /usr/bin/

#检查是否存在/etc/my.cnf个文件,如果存在那么就以当天日期重命名这个文件然后备份为bak,例如my.cnf.20240905140424.bak
if [ -s /etc/my.cnf ]; then
    mv /etc/my.cnf /etc/my.cnf.`date +%Y%m%d%H%M%S`.bak
fi



#创建一个新的/etc/my.cnf文件,然后将以下内容写进去,直至遇到EOF这个标识符,EOF之后的内容就别写进去了 
cat >/etc/my.cnf <<EOF
[mysqld]
read_only                                   = 0
show_compatibility_56                       = 1
port                                        = 3306
server_id                                   = $serverid
user                                        = mysql
basedir                                     = /usr/local/mysql
datadir                                     = /vdb/mysql/data
socket                                      = /vdb/mysql/tmp/mysql.sock
tmpdir                                      = /vdb/mysql/tmp
character_set_server                        = utf8mb4
transaction_isolation                       = READ-COMMITTED
event_scheduler                             = 1
default-time-zone                           = "+8:00"
log_timestamps                              = SYSTEM
explicit_defaults_for_timestamp             = 1
secure_file_priv                            = ""
skip_slave_start                            = 1
skip_name_resolve                           = 1
skip_external_locking                       = 1
lower_case_table_names                      = 1
default_storage_engine                      = InnoDB
disabled_storage_engines                    = ARCHIVE,BLACKHOLE,EXAMPLE,FEDERATED,MEMORY,MERGE,NDB
 
# connection #
lock_wait_timeout                           = 1800
max_connections                             = 3000
max_connect_errors                          = 1000000
interactive_timeout                         = 1800
wait_timeout                                = 1800
 
# session memory setting #
read_buffer_size                            = 8M
read_rnd_buffer_size                        = 8M
sort_buffer_size                            = 2M
tmp_table_size                              = 64M
join_buffer_size                            = 64M
max_heap_table_size                         = 64M
max_allowed_packet                          = 64M
 
# cache config #
key_buffer_size                             = 16M
table_definition_cache                      = 2000
table_open_cache                            = 2000
table_open_cache_instances                  = 8
query_cache_type                            = 0
query_cache_size                            = 0
thread_cache_size                           = 200
open_files_limit                            = 65536
binlog_cache_size                           = 1M
max_binlog_cache_size                       = 512M
 
# log config #
log_bin                                     = /vdb/mysql/binlog/mysql-bin
binlog_format                               = row
sync_binlog                                 = 1
binlog_error_action                         = ABORT_SERVER
max_binlog_size                             = 250M
binlog_rows_query_log_events                = 1
expire_logs_days                            = 7
log_bin_trust_function_creators             = 1
log_slave_updates                           = 1
relay_log                                   = /vdb/mysql/binlog/mysql-relay
relay_log_recovery                          = 1
master_info_repository                      = TABLE
relay_log_info_repository                   = TABLE
log_error                                   = /vdb/mysql/logs/error.log
slow_query_log                              = 1
slow_query_log_file                         = /vdb/mysql/logs/slow.log
long_query_time                             = 5
log_queries_not_using_indexes               = 1
log_slow_admin_statements                   = 1
log_slow_slave_statements                   = 1
log_throttle_queries_not_using_indexes      = 10
min_examined_row_limit                      = 100
 
# innodb settings #
innodb_data_home_dir                        = /vdb/mysql/data
innodb_log_group_home_dir                   = /vdb/mysql/data
innodb_file_per_table                       = 1
innodb_data_file_path                       = ibdata1:1G:autoextend
innodb_flush_log_at_trx_commit              = 1
innodb_buffer_pool_size                     = ${buffer}M
innodb_buffer_pool_instances                = 8
innodb_buffer_pool_load_at_startup          = 1
innodb_buffer_pool_dump_at_shutdown         = 1
innodb_buffer_pool_dump_pct                 = 25
innodb_lock_wait_timeout                    = 10
innodb_io_capacity                          = 10000
innodb_io_capacity_max                      = 20000
innodb_max_dirty_pages_pct                  = 60
innodb_flush_method                         = O_DIRECT
innodb_log_file_size                        = 2G
innodb_log_files_in_group                   = 2
innodb_log_buffer_size                      = 64M
innodb_purge_threads                        = 2
innodb_write_io_threads                     = 16
innodb_read_io_threads                      = 16
innodb_large_prefix                         = 1
innodb_thread_concurrency                   = 64
innodb_print_all_deadlocks                  = 1
innodb_strict_mode                          = 1
innodb_sort_buffer_size                     = 32M
innodb_stats_persistent_sample_pages        = 64
innodb_autoinc_lock_mode                    = 2
innodb_online_alter_log_max_size            = 1G
innodb_open_files                           = 4096
innodb_temp_data_file_path                  = ibtmp1:12M:autoextend:max:20G
 
# undo config #
innodb_rollback_segments                    = 128
innodb_undo_log_truncate                    = 1
innodb_max_undo_log_size                    = 4G
 
# GTID #
gtid_mode                                   = ON
enforce_gtid_consistency                    = 1
binlog_gtid_simple_recovery                 = 1
 
# MTS #
slave_parallel_type                         = LOGICAL_CLOCK
slave_parallel_workers                      = 16
slave_preserve_commit_order                 = ON
slave_rows_search_algorithms                = 'INDEX_SCAN,HASH_SCAN'
 
# SEMISYNC #
plugin-load                                 = "rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so"
rpl_semi_sync_master_enabled                = 1
rpl_semi_sync_slave_enabled                 = 1
rpl_semi_sync_master_timeout                = 60000     #1min
rpl_semi_sync_master_wait_for_slave_count   = 1
rpl_semi_sync_master_wait_no_slave          = 0
 
# Performance Schema Config #
performance-schema-instrument               = 'wait/lock/metadata/sql/mdl=ON'
performance-schema-instrument               = 'memory/%=COUNTED'
 
# Other #
innodb_numa_interleave                      = 1
 
[mysqldump]
quick
max_allowed_packet                          = 2G
log-error                                   = /vdb/mysql/logs/dump.log
net_buffer_length                           = 8K
 
[mysqladmin]
default-character-set                       = utf8mb4
socket                                      = /vdb/mysql/tmp/mysql.sock
 
[client]
port                                        = 3306
socket                                      = /vdb/mysql/tmp/mysql.sock
 
[mysql]
prompt                                      = [\\u@\\h][\\d]:\\_
default-character-set                       = utf8mb4
no-auto-rehash
 
EOF


#这里用的是>>,是追加新内容到/root/.bash_profile,并不是全覆盖。
#然后将以下内容写进去,直至遇到EOF这个标识符,EOF之后的内容就别写进去了 
cat >>/root/.bash_profile <<EOF
export PATH=/usr/local/mysql/bin:\$PATH
EOF
刷新/root/.bash_profile这个文件并使之生效
source /root/.bash_profile

#这段命令用于启动 MySQL 服务器,并指定了一些重要的参数:
#/usr/local/mysql/bin/mysqld这个是mysql的启动项,相当于windows桌面上的启动图标双击一下就运行该软件了
# --defaults-file=/etc/my.cnf:指定了配置文件的路径。
#--user=mysql:指定以 mysql 用户身份运行服务器。
#--datadir=/vdb/mysql/data:指定数据存储的目录。
#--basedir=/usr/local/mysql:指定 MySQL 的安装目录。
#--initialize-insecure:执行不安全的初始化,这可能意味着设置一些默认的、不太严格的安全选项来快速初始化数据库。
/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --user=mysql --datadir=/vdb/mysql/data --basedir=/usr/local/mysql --initialize-insecure

#把/usr/local/mysql/support-files/mysql.server复制到/etc/init.d/这个文件夹里面去,取名为mysqld
#/etc/init.d/ 文件夹通常用于存放系统服务和守护进程的启动、停止、重启等操作的脚本。
#也就是说我们这样手动安装的软件mysql,以后也可以用systemctl start mysql这样的命令来启动mysql了比较方便。
# /usr/local/mysql/support-files/mysql.server这个文件其实就是一个程序脚本,你看路径名里都有一个support-files
#就是为了方便后续用户可以添加到linux系统里面的快捷启动方式里面(systemctl)。
#但是上面那个/usr/local/mysql/bin/mysqld是mysql的启动文件,这个不是一个脚本,用vim是打不开的,看不到里有啥内容
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
#赋予/etc/init.d/mysqld具有可执行的权限
chmod 755 /etc/init.d/mysqld
#将名为 mysqld 的服务添加到系统的服务管理配置中,方便可以用systemctl来控制启动、停止等状态
chkconfig --add mysqld
#设置 MySQL 服务(mysqld)在运行级别 2、3、4、5 中为开机自启动(on)状态。
#运行级别是系统在不同模式下的运行状态,例如,2 通常是多用户模式但没有网络,3 是多用户模式带网络,4 通常未被使用,5 是带有图形界面的多用户模式。
chkconfig --level 2345 mysqld on

#将”/usr/local/mysql/lib“写入到/etc/ld.so.conf.d/mysql-x86_64.conf里面去
cat  >> /etc/ld.so.conf.d/mysql-x86_64.conf<<EOF
/usr/local/mysql/lib
EOF

#刷新系统的共享库缓存,以便程序能够正确找到和加载所需的共享库
ldconfig
#用于检查/proc/vz是否为一个目录,条件为真,就会执行then后面的语句
#ulimit -s unlimited 这条命令用于设置栈大小(stack size)为无限制(unlimited)。
#在某些情况下,如果程序需要较大的栈空间来处理复杂的操作或递归调用,可能会使用这条命令来避免栈空间不足导致的错误。
if [ -d "/proc/vz" ]; then
    ulimit -s unlimited
fi

#使用systemctl来启动mysql
systemctl start mysqld.service
# 创建监控用户,只读用户,复制用户 
/usr/local/mysql/bin/mysqladmin -u root password $pwd > /dev/dull

#把这两句SQL语句写入到/tmp/mysql_sec_scripts里面去
#这段 SQL 语句的作用是授予用户 'repl_user'@'%' 复制从服务器的权限。
#*.* 表示在所有数据库和所有表上授予权限。
#identified by '$rplpwd' 表示设置该用户的密码为 $rplpwd 变量所代表的值。
#flush privileges是刷新授权表;
cat > /tmp/mysql_sec_scripts<<EOF
grant replication slave on *.* to 'repl_user'@'%' identified by  '$rplpwd';
flush privileges;
EOF

# 使用 /usr/local/mysql/bin/mysql 这个 MySQL 客户端程序,
#以 root 用户身份,密码由 $pwd 变量指定,连接到本地主机(localhost)上的 MySQL 服务器
#并执行 /tmp/mysql_sec_scripts 文件中的 SQL 语句
#  /usr/local/mysql/bin/mysql和刚才上面提到的/usr/local/mysql/bin/mysqld是不太一样的
# mysql是客户端程序,mysqld是主程序,主程序是运行在背后,但是我们人类想看mysql数据库里面的各种数据库具体表格
#就需要用到mysql客户端了,用mysql客户端连接背后的数据库用SQL语句进行相关的增删改查交互操作
/usr/local/mysql/bin/mysql -u root -p$pwd -h localhost </tmp/mysql_sec_scripts
#删除/tmp/mysql_sec_scripts
rm -f /tmp/mysql_sec_scripts
#检查MySQL主程序有没有运行,在运行就赋值mcheck为1,否则为0
mcheck=`systemctl status mysqld.service|grep 'active (running)'|wc -l`
#如果/usr/local/mysql/bin/mysql存在,并且/usr/local/mysql/bin/mysqld_safe也存在,
#并且/etc/my.cnf也存在,并且MySQL主程序在运行中
#那么输出MySQL 5.7 install completed,以及MySQL网络连接状态信息,不然就输出安装失败Failed
#ss -anutlp | grep 3306就是使用 ss 命令查看所有的网络连接状态信息;
#(包括套接字的类型、状态、本地地址和端口、远程地址和端口等),然后通过 grep 3306 筛选出与端口 3306 相关的连接信息。
if [ -s /usr/local/mysql/bin/mysql ] && [ -s /usr/local/mysql/bin/mysqld_safe ] && [ -s /etc/my.cnf ] && [ $mcheck -eq 1 ]; then
    echo ""
    echo "MySQL 5.7 install completed"
    ss -anutlp | grep 3306
else
    echo "Error: MySQL Install Failed!!"
fi

================================================================================

创作不易,给点小小的支持吧

在这里插入图片描述
在这里插入图片描述

标签:脚本,grep,mysql,linux,cnf,etc,export,MySQL,my
From: https://blog.csdn.net/qq_37263429/article/details/141928749

相关文章

  • mysql sql开发01
    mysqlsql开发创建表  创建表语法:    --基本语法      CREATETABLE表名称(      字段名1数据类型1,      字段名2数据类型2,      字段名3数据类型3);例子:创建一个actor表,包含如下列信息列表类......
  • Linux 内核 6.11 RC6 发布!
    2024年9月2日,Linux内核开发者LinusTorvalds宣布了Linux内核6.11的第六个候选版本(RC6)的发布。与以往的发布时间相比,由于Torvalds正在国外旅行,这次的RC6提前半天发布。这是6.11版本开发周期的又一部分,主要是继续修复和稳定系统的各个组成部分,特别是文件系统、......
  • Linux文本处理大纲
    目录一、正则表达式二、字符串截取命令(1)cut命令(2)printf命令(3)awk命令1、条件(pattern):一般使用关系表达式作为条件2、动作(Action):格式化输出流程控制语句三、字符串处理命令(1)排序命令sort(2)统计命令wc一、正则表达式正则表达式用来在文件中匹配符合条件的字符串,正......
  • Mysql-慢SQL的处理以及SQL优化
    前言开发过程中,从日志或者链路追踪中,我们可以统计和观察到慢SQL的存在,那么慢SQL需要如何去考虑以及修改呢?考虑:1、是否使用索引、是否load过多不需要的数据、数据库数据过多命中索引,尽量使用合适的索引重写SQL,查询的字段尽量精准,where过滤条件越精准的往前放清除老数据......
  • linux系统下各种日志文件的介绍,查看,及日志服务配置
    转载于https://zhuanlan.zhihu.com/p/298335887,侵权删!linux系统日志文件的详细介绍日志文件的作用日志文件用于记录linux系统的各种运行信息的文件,相当于linux主机的日记,不同的日志文件记载了不同类型的信息,如Linux内核消息、用户登录事件、程序错误等。.日志文件对于诊断和......
  • Linux 系统中的 `/etc/sysctl.conf` 配置文件内核参数设置
    以下是对这些参数的详细解释:网络参数net.ipv4.ip_forward=0:禁用IP转发,防止系统作为路由器转发数据包。net.ipv4.conf.default.rp_filter=1:启用反向路径过滤,增加网络安全性,防止IP地址欺骗。net.ipv4.conf.default.accept_source_route=0:禁用源路由选项,防止数据包通......
  • mysql 常用sql
    select@name:=underlineToCamel(t.COLUMN_NAME)'列名',@type:=casewhent.DATA_TYPEin('varchar','char','text','longtext','mediumtext','mediumblob')then......
  • 基于微信小程序+JavaSSM+MySQL的音乐播放器设计与实现 毕业论文+前后端项目源码及数据
    !!!有需要的小伙伴可以通过文章末尾名片咨询我哦!!! ......
  • MySQL(三)操作符 连接操作
    LIKE操作符用于在WHERE子句中搜索列中的指定模式,是进行模糊查询的关键字通常与%和_通配符一起使用SELECTcolumn1,column2,...FROMtable_nameWHEREcolumn_nameLIKEpattern;通配符%:匹配任意字符(包括零个字符)_:匹配单个字符_的用法:使用_通配符找出所有......