MySQL搭建系列之多实例
所谓多实例。就是在一台server上搭建、执行多个MySQL实例,每一个实例使用不同的服务port。通过不同的socket监听;物理上,每一个实例拥有独立的參数配置文件及数据库。
通常情况下。一台server是不建议执行多个MySQL实例的。尤其是生产环境,由于这会造成资源相互强占问题。但在一些高可用环境中。却有这种需求,比方:利用Heartbeat搭建的故障转移集群环境。若主备server仅仅执行一个MySQL实例,则备用server寻常处于闲置状态,造成了资源浪费;若各自执行一个MySQL实例,则在一方故障时,要求还有一方接管其任务。即同一时候执行两个MySQL实例。基于这个需求,应合理配置MySQLserver,使其具备同一时候执行多个实例的能力。
怎样才干在一台server上搭建、执行多个MySQL实例,其关键在于怎样为每一个实例分配独立的參数文件,下面是几种经常使用的多实例方案,分别来学习、熟悉一下。
系统环境
OS:CentOS 5.8 (x86_64) 内核:2.6.18-308.el5 DB:MySQL 5.5.17
一. 採用源代码包安装MySQL实现多实例
源代码包是最灵活的安装包,可定制编译一些路径參数,可安装到不论什么路径,因此可在一台server搭建多个MySQL实例。本例安装两个MySQL实例。过程例如以下:
1. 准备工作
从MySQL 5.5開始,改用cmake工具来编译源代码包,所以要首先安装它,可參考其他文档。此处不做解说。另外。编译之前还需安装ncurses-devel、bison两个依赖包。否则会编译失败。
――安装依赖包
# rpm -ivh ncurses-devel-5.5-24.20060715.x86_64.rpm
# rpm -ivh bison-2.3-2.1.x86_64.rpm
――创建mysql系统组及用户
# groupadd -g 497 mysql
# useradd –u 499 -g mysql mysql
――解压安装包
# tar -zxvf mysql-5.5.17.tar.gz
# cd mysql-5.5.17
2. 编译、安装
l MySQL实例1:
(port:3306。安装文件夹:/usr/local/mysqla,数据文件文件夹:/data/lib/mysqla)
――定制编译
# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysqla-DMYSQL_TCP_PORT=3306 -DMYSQL_DATADIR=/data/lib/mysqla-DMYSQL_UNIX_ADDR=/data/lib/mysqla/mysql.sock -DSYSCONFDIR=/usr/local/mysqla-DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1-DWITH_PARTITION_STORAGE_ENGINE=1 -DENABLED_LOCAL_INFILE=1 -DWITH_READLINE=1-DWITH_SSL=yes -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci-DEXTRA_CHARSETS=all
# make
# make install
――创建系统数据库及系统表
# cd /usr/local/mysqla/
# scripts/mysql_install_db --user=mysql--basedir=/usr/local/mysqla --datadir=/data/lib/mysqla
l MySQL实例2:
(port:3307,安装文件夹:/usr/local/mysqlb,数据文件文件夹:/data/lib/mysqlb)
――删除旧的缓存及对象文件
再次编译之前。要清除原来的缓存信息及对象文件,例如以下:
# cd mysql-5.5.17
# make clean
# rm -rf CMakeCache.txt
――定制编译
# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysqlb-DMYSQL_TCP_PORT=3307 -DMYSQL_DATADIR=/data/lib/mysqlb-DMYSQL_UNIX_ADDR=/data/lib/mysqlb/mysql.sock -DSYSCONFDIR=/usr/local/mysqlb-DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1-DWITH_PARTITION_STORAGE_ENGINE=1 -DENABLED_LOCAL_INFILE=1 -DWITH_READLINE=1-DWITH_SSL=yes -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci-DEXTRA_CHARSETS=all
# make
# make install
――创建系统数据库及系统表
# cd /usr/local/mysqlb/
# scripts/mysql_install_db --user=mysql--datadir=/data/lib/mysqlb
3. 配置參数文件
经过上面两次编译并创建系统数据库。安装、搭建了两个MySQL实例,接下来分别为其配置參数文件。
――查看參数文件缺省位置
# /usr/local/mysqla/bin/mysql --help|grep '/my.cnf'
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysqla/my.cnf ~/.my.cnf
# /usr/local/mysqlb/bin/mysql --help|grep '/my.cnf'
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysqlb/my.cnf ~/.my.cnf
从中能够看出,两个MySQL实例的4个缺省參数文件里有3个是同样的。所以不能採用。否则就无法区分了;当然。多个实例间同样的參数部分可如此配置,仅仅只是不便于管理。
为了使每一个MySQL实例拥有一个独立的參数文件。仅仅能採用第3个缺省參数文件,即将參数文件存放到各实例自己的安装文件夹下(basedir)。
另外。还需保证不存在第4个參数文件。由于它的优先级别较高,若存在则会覆盖前面的參数文件设置。
关于參数文件的具体配置此处不做说明了,如果已为两个MySQL实例配置好了各自的參数文件,并分别存放在各自的安装文件夹下。即/usr/local/mysqla|mysqlb文件夹下。
4. 启动实例
启动MySQL实例。须要为datadir文件夹设置正确的权限。否则实例启动失败。这一步缺省应该已经设置。检查一下。若未设置。则通过例如以下命令设置。
# chown -R mysql.mysql mysql/
――启动两个MySQL实例
# /usr/local/mysqla/bin/mysqld_safe --user=mysql &
# /usr/local/mysqlb/bin/mysqld_safe --user=mysql &
――查看进程
# ps -ef|grep mysql
root 1694 26876 0 13:04 pts/2 00:00:00 more/usr/local/mysqla/support-files/mysql.server
root 2270 13474 0 13:13 pts/1 00:00:00 /bin/sh/usr/local/mysqla/bin/mysqld_safe --user=mysql
mysql 2805 2270 113:13 pts/1 00:00:00 /usr/local/mysqla/bin/mysqld--basedir=/usr/local/mysqla --datadir=/data/lib/mysqla--plugin-dir=/usr/local/mysqla/lib/plugin --user=mysql--log-error=/data/lib/mysqla/mysql.err --pid-file=/data/lib/mysqla/mysql.pid--socket=/data/lib/mysqla/mysql.sock
--port=3306
root 2828 13474 0 13:13 pts/1 00:00:00 /bin/sh/usr/local/mysqlb/bin/mysqld_safe --user=mysql
mysql 3361 2828 25 13:13 pts/1 00:00:00 /usr/local/mysqlb/bin/mysqld--basedir=/usr/local/mysqlb --datadir=/data/lib/mysqlb --plugin-dir=/usr/local/mysqlb/lib/plugin--user=mysql --log-error=/data/lib/mysqlb/mysql.err--pid-file=/data/lib/mysqlb/mysql.pid
--socket=/data/lib/mysqlb/mysql.sock--port=3307
root 3381 13474 0 13:13 pts/1 00:00:00 grep mysql
能够看出,成功启动了两个MySQL实例(进程)
――若要关闭服务,可运行例如以下命令
# /usr/local/mysqla/bin/mysqladmin shutdown
# /usr/local/mysqlb/bin/mysqladmin shutdown
5. 改动为服务管理方式
为了方便管理,将其改动为服务管理方式,例如以下:
――拷贝服务文件
# cp /usr/local/mysqla/support-files/mysql.server/etc/rc.d/init.d/mysqla
# cp /usr/local/mysqlb/support-files/mysql.server/etc/rc.d/init.d/mysqlb
――加入服务
# chkconfig --add mysqla
# chkconfig --list mysqla
mysqla 0:off 1:off 2:on 3:on 4:on 5:on 6:off
# chkconfig --add mysqlb
# chkconfig --list mysqlb
mysqlb 0:off 1:off 2:on 3:on 4:on 5:on 6:off
――启动服务
# service mysqla start
Starting MySQL.. [ OK ]
[root@db ~]# service mysqlb start
Starting MySQL.. [ OK ]
至此,我们通过源代码包成功搭建了两个MySQL实例。它们拥有独立的port、參数文件及数据库。
二. 採用二进制包安装MySQL实现多实例
二进制包事实上就是已经过编译的源代码包,不能再通过定制參数文件缺省路径的方法来隔离各个实例的參数文件了;但有一点须要说明的是:第3个參数文件的缺省路径指的是basedir(安装文件夹)。可通过它来隔离各实例的參数文件,因此一台server也就可搭建多个MySQL实例了。
相同安装两个MySQL实例,过程例如以下:
1. 准备工作
――创建mysql系统组及用户
# groupadd -g 497 mysql
# useradd -u 499 -g mysql mysql
――解压安装包
将二进制安装包解压到/usr/local/文件夹中。并改名为mysql,这是二进制包编译时basedir參数的缺省文件夹。
# tar zxvf mysql-5.5.17-linux2.6-x86_64.tar.gz -C /usr/local/
# cd /usr/local/
# mv mysql-5.5.17-linux2.6-x86_64 mysql
――拷贝解压后的mysql。生成例如以下两个文件夹,以用作两个实例的安装文件夹
# cd /usr/local/
# cp -R mysql mysqla
# cp -R mysql mysqlb
# ll
drwxr-xr-x 12 root root 4096 Sep 27 14:33 mysql
drwxr-xr-x 12 root root 4096 Sep 27 14:36 mysqla
drwxr-xr-x 12 root root 4096 Sep 27 14:37 mysqlb
备注:此处保留mysql这个文件夹,是为了配置硬连接,以便在不论什么文件夹下,都能够訪问mysqlclient程序。
2. 创建系统数据库
为两个MySQL实例创建系统数据库,basedir分别为/usr/loca/mysqla|mysqlb。datadir分别为/data/lib/mysqla|mysqlb。例如以下:
# cd /usr/local/mysql/
# scripts/mysql_install_db --user=mysql--basedir=/usr/local/mysqla --datadir=/data/lib/mysqla
# scripts/mysql_install_db --user=mysql--basedir=/usr/local/mysqlb --datadir=/data/lib/mysqlb
3. 配置參数文件
为了使每一个MySQL实例拥有独立的參数文件,将其存放在各自的安装文件夹下(basedir),且需保证缺省路径下不存在參数文件,以防读取错误。
如果參数文件已配置好。port分别为3306、3307,basedir分别为/usr/local/mysqla、/usr/local/mysqlb。datadir分别为/data/lib/mysqla、/data/lib/mysqlb。
4. 启动实例
这样的情况下,可在启动实例时通过--defaults-file为其指定一个參数文件。例如以下:
# /usr/local/mysql/bin/mysqld_safe--defaults-file=/usr/local/mysqla/my.cnf &
# /usr/local/mysql/bin/mysqld_safe--defaults-file=/usr/local/mysqlb/my.cnf &
关闭实例时。相同须要指定其參数文件,否则会失败。
# /usr/local/mysql/bin/mysqladmin--defaults-file=/usr/local/mysqla/my.cnf shutdown
# /usr/local/mysql/bin/mysqladmin--defaults-file=/usr/local/mysqlb/my.cnf shutdown
5. 改动为服务管理方式
二进制包没有採用缺省參数文件。所以改动为服务管理方式略微有点复杂,须要改动服务启动文件里的basedir、datadir參数。例如以下:
――拷贝服务文件
# cp /usr/local/mysql/support-files/mysql.server/etc/rc.d/init.d/mysqla
# cp /usr/local/mysql/support-files/mysql.server/etc/rc.d/init.d/mysqlb
――加入服务
# chkconfig --add mysqla
# chkconfig --add mysqlb
――改动服务启动文件
编辑两个服务启动文件,改动basedir、datadir參为合适的路径,例如以下:
# vi /etc/rc.d/init.d/mysqla
basedir=/usr/local/mysqla
datadir=/data/lib/mysqla
# vi /etc/rc.d/init.d/mysqlb
basedir=/usr/local/mysqlb
datadir=/data/lib/mysqlb
备注:通过显式设置basedir,以使每一个MySQL实例拥有独立的參数文件。
――启动服务
# service mysqla start
Starting MySQL.. [ OK ]
# service mysqlb start
Starting MySQL.. [ OK ]
# service mysqlb status
MySQL running (30326) [ OK ]
# service mysqla status
MySQL running (29755) [ OK ]
改动为服务管理方式后,启动、关闭服务方便了,但在本地登录数据库。还需指定socket文件,由于缺省的/tmp/mysql.sock并不存在,如:
# mysql --socket=/data/lib/mysqla/mysql.sock
# mysql --socket=/data/lib/mysqlb/mysql.sock
三. 採用RPM包安装MySQL实现多实例
RPM包的文件布局是固定的,无法改动,因此一台server通常仅仅能安装一个MySQL实例。但我们知道。不管何种方式,MySQL实例都是通过调用mysqld_safe命令来启动的,而mysqld_safe命令可通过--defaults-file參数来显式指定一个參数文件,因此相同可在一台server安装、执行多个MySQL实例,仅仅只是要对服务启动文件做一些调整。以下就来尝试一下这种方法。
1. 安装MySQL
――安装server及client包
# rpm -ivh MySQL-server-5.5.17-1.rhel5.x86_64.rpm
# rpm -ivh MySQL-client-5.5.17-1.rhel5.x86_64.rpm
――启动服务
# service mysql start
Starting MySQL.. [ OK ]
――查看basedir和datadir參数值
# mysql
mysql> show variables like 'basedir';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| basedir |/usr |
+---------------+-------+
1 row in set (0.00 sec)
mysql> show variables like 'datadir';
+---------------+-----------------+
| Variable_name | Value |
+---------------+-----------------+
| datadir |/var/lib/mysql/ |
+---------------+-----------------+
1 row in set (0.01 sec)
从中能够看出basedir缺省为/usr。datadir缺省为/var/lib/mysql。
2. 创建系统数据库
缺省情况下。RPM包已创建了系统数据库,位于/var/lib/mysql文件夹下。拷贝这个文件夹到/data/lib文件夹下。并分别命名为mysqla、mysqlb。以此来创建两个实例的系统数据库。
# service mysql stop
Shutting down MySQL. [ OK ]
# cp -r /var/lib/mysql/ /data/lib/mysqla
# cp -r /var/lib/mysql/ /data/lib/mysqlb
当然,也可通过mysql_install_db工具来创建。它位于/usr/bin文件夹下,例如以下:
# /usr/bin/mysql_install_db --user=mysql--datadir=/data/lib/mysqla
# /usr/bin/mysql_install_db --user=mysql--datadir=/data/lib/mysqlb
3. 配置參数文件
配置两个參数文件,分别命名为mya.cnf、myb.cnf,存放到/etc/文件夹下。port号分别为3306、3307,datadir路径分别为/data/lib/mysqla、/data/lib/mysqlb。
4. 启动实例
同二进制包多实例一样,此时启动、关闭实例时仅仅能通过--defaults-file指定參数文件。例如以下:
# /usr/bin/mysqld_safe --defaults-file=/etc/mya.cnf &
# /usr/bin/mysqld_safe --defaults-file=/etc/myb.cnf &
# /usr/bin/mysqladmin --defaults-file=/etc/mya.cnf shutdown
# /usr/bin/mysqladmin --defaults-file=/etc/myb.cnf shutdown
5. 改动服务管理方式
为了方便,还是要将其改动为服务管理方式。运行例如以下改动操作。
――创建服务启动文件
依据服务启动文件mysql,创建两个相应服务启动文件mysqla、mysqlb
# cd /etc/rc.d/init.d/
# cp mysql mysqla
# cp mysql mysqlb
――加入服务
# chkconfig --add mysqla
# chkconfig --add mysqlb
――删除原来的服务启动文件及服务(避免误启动)
# chkconfig --del mysql
# rm /etc/rc.d/init.d/mysql
――改动服务启动文件
编辑服务启动文件,进行例如以下调整。主要有下面几个地方:
# vi /etc/rc.d/init.d/mysqla
l 1:加入一个变量。设置为參数文件
my_cnf=/etc/mya.cnf
l 2:改动extra_args參数值,目的是让parse_server_arguments函数从中解析出datadir等參数值
(红色字体为加入部分)
extra_args=""
if test -r "$basedir/my.cnf"
then
extra_args="-e$basedir/my.cnf"
else
if test -r"$datadir/my.cnf"
then
extra_args="-e$datadir/my.cnf"
else
extra_args="-e $my_cnf"
fi
fi
l 3:在mysqld_safe命令中使用--defaults-file以便显式指定一个參数文件
$bindir/mysqld_safe --defaults-file=$my_cnf--datadir="$datadir" --pid-file="$mysqld_pid_file_path"$other_args >/dev/null 2>&1 &
注意:一定要将--defaults-file參数紧跟mysqld_safe,中间不能有其它參数。否则启动失败。
l 4:改动lock_file_path,若未改动,虽还不清楚有啥影响。但以防万一,还是改动之
lock_file_path="$lockdir/mysqla"
l 5:找到'status',将获取mysqld进程的命令pidof替换为ps
#mysqld_pid=`pidof $libexecdir/mysqld`
mysqld_pid=`ps --user=mysql -f|grep "$libexecdir/mysqld--defaults-file=$my_cnf"|awk '{print $2}'`
说明:pidof命令用于获取$libexecdir/mysqld的进程号,进而推断MySQL实例的状态,因为路径及名称都是固定的,所以无法区分每一个实例相应的进程。导致Status混乱。用ps命令的过滤功能可实现这个需求,针对每一个实例找到其相应的进程。
依照相同的方法。为第二个MySQL实例调整服务启动文件。
――启动服务
[root@db mysqla]# service mysqla start
Starting MySQL.. [ OK ]
[root@db mysqla]# service mysqlb start
Starting MySQL.. [ OK ]
至此。我们通过RPM包在一台server上安装了两个MySQL实例。
四. 採用mysqld_multi工具实现多实例
mysqld_multi是MySQL自带的一个统一管理多个MySQL实例的服务脚本。它会从MySQL的參数文件里搜索[mysqld#]段序列(#即GNR,能够是随意的正整数),作为自己的參数。以此来区分不同的段,进而控制特定的mysqld进程(MySQL实例)的启动、停止或者获取报告信息。
以下我们採用来了解一下它是怎样管理多个MySQL实例的。
1. 配置參数文件
mysqld_multi与安装包类型无关,所以不管是源代码包、二进制包,还是RPM包都自带了这个程序脚本,如果MySQL已安装成功。
鉴于mysqld_multi的工作机制,要求MySQL的參数文件里配置[mysqld_multi]项。及多个[mysqld#]段。每一个[mysqld]段相应一个MySQL实例。使用不同的port及unix socket监听文件。
本例配置两个[mysqld#]段,例如以下:
# vi /etc/my.cnf
[mysqld_multi]
mysqld =/usr/bin/mysqld_safe
mysqladmin = /usr/bin/mysqladmin
[mysqld1]
port = 3306
server-id = 3306
datadir =/data/lib/mysqla
socket =/data/lib/mysqla/mysql.sock
pid-file =/data/lib/mysqla/mysql.pid
character-set-server =utf8
default_storage_engine = InnoDB
log-bin =/data/lib/mysqla/mysql-bin
binlog_format = row
sync-binlog = 1
slow-query-log = on
slow-query-log-file = /data/lib/mysqla/mysql-slow.log
log_error =/data/lib/mysqla/mysql.err
max_connections =2000
back_log =50
skip-external-locking
skip-name-resolve
#skip-networking
key_buffer_size =256M
max_allowed_packet =1M
table_open_cache = 2000
sort_buffer_size =1M
read_buffer_size =1M
read_rnd_buffer_size =4M
myisam_sort_buffer_size = 64M
thread_cache_size =8
query_cache_size =16M
thread_concurrency =8
innodb_data_home_dir = /data/lib/mysqla
innodb_data_file_path = ibdata1:10M:autoextend
innodb_log_group_home_dir = /data/lib/mysqla
innodb_buffer_pool_size = 256M
innodb_additional_mem_pool_size = 20M
innodb_log_file_size = 64M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
[mysql2]
port = 3307
server-id = 3307
datadir =/data/lib/mysqlb
socket =/data/lib/mysqlb/mysql.sock
pid-file =/data/lib/mysqlb/mysql.pid
character-set-server =utf8
default_storage_engine = InnoDB
log-bin =/data/lib/mysqlb/mysql-bin
binlog_format = row
sync-binlog = 1
slow-query-log = on
slow-query-log-file = /data/lib/mysqlb/mysql-slow.log
log_error =/data/lib/mysqlb/mysql.err
max_connections =2000
back_log =50
skip-external-locking
skip-name-resolve
#skip-networking
key_buffer_size =256M
max_allowed_packet =1M
table_open_cache = 2000
sort_buffer_size =1M
read_buffer_size =1M
read_rnd_buffer_size =4M
myisam_sort_buffer_size = 64M
thread_cache_size =8
query_cache_size =16M
thread_concurrency =8
innodb_data_home_dir = /data/lib/mysqlb
innodb_data_file_path = ibdata1:10M:autoextend
innodb_log_group_home_dir = /data/lib/mysqlb
innodb_buffer_pool_size = 256M
innodb_additional_mem_pool_size = 20M
innodb_log_file_size = 64M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
[mysqld_multi]项指定了mysqld_safe及mysqladmin命令工具,mysqld_multi也就是通过这两个工具来管理MySQL实例的。两个[mysqld#]段,分别相应两个MySQL实例,port分别为3306、3307。datadir分别为/data/lib/mysqla、/data/lib/mysqlb。
2. 使用mysqld_multi
――通过mysqld_multi启动、关闭MySQL实例
# /usr/bin/mysqld_multi start|stop 1
# /usr/bin/mysqld_multi start|stop 2
备注:此处的1、2分别表示參数配置文件里的[mysqld1]、[mysqld2]。相应着两个MySQL实例;若此处不输入要操作的段序列。则缺省启动、关闭全部[mysqld]段。
为了方便。将其改动为服务管理方式。详细操作例如以下:
――拷贝服务文件
将mysqld_multi.server文件复制到/etc/rc.d/init.d/文件夹下。并改个简单点的名字
(mysqld_multi.server文件的详细位置因安装方式不同而不同)
# cp /usr/share/mysql/mysqld_multi.server/etc/rc.d/init.d/mysqld_m
――加入服务
# chkconfig --add mysqld_m
# chkconfig --list mysqld_m
mysqld_m 0:off 1:off 2:on 3:on 4:on 5:on 6:off
――改动服务文件
改动/etc/rc.d/init.d/mysqld_m文件里的两个參数。例如以下:
# vi /etc/rc.d/init.d/mysqld_m
basedir=/usr/
bindir=/usr/bin
备注:这两个參数的缺省值分别为/usr/local/mysql、/urs/local/mysql/bin,不同类型的安装包,实际值可能不同,依据自己的实际情况,改动这两个參数的值。以便启动脚本可以找到/usr/bin/mysqld_multi文件。并赋予该文件操作权限。
――启动、关闭实例
改动完毕后,我们就能够通过mysqld_multi启动mysqld实例了。其语法例如以下:
#mysqld_m [options][GNR[,GNR]...]
# service mysqld_m start|stop 1
# service mysqld_m start|stop 2
3. 不足之处
mysqld_multi统一管理多个MySQL实例,虽有方便之处,但在使用过程中。也发现了一些不足之处,一是选项过于简单,仅仅有start、stop、report。而没有status项,所以无法查看服务的状态。二是在启动、关闭服务时,仅仅是运行start、stop这么一个操作,而不跟踪操作结果,所以无法确保操作成功运行。
MySQL搭建系列之多实例的更多相关文章
- 服务器环境搭建系列(四)-mysql篇
1.按照上一篇服务器环境搭建系列(三)-JDK篇中的方法检查系统是否已经预装Mysql并卸载. 2.下载mysql,这里是MySQL-server-5.5.25-1.linux2.6.x86_64.r ...
- [转]Ubuntu10下MySQL搭建Amoeba系列(文章索引)
一.前言(Introduction) 使用了Amoeba有一段时间了,发现官方博客:Amoeba使用指南有很多地方都是错误的,在我实战中给到一些错误的指示,所以我想写些在搭建的实战中给大家一点指引.欢 ...
- Oracle_lhr_CentOS 7.3 ECS上搭建RAC 18c+单实例DG+EMCC+DG的FSFO快速故障转移配置
Oracle_lhr_CentOS 7.3 ECS上搭建RAC 18c+单实例DG+EMCC+DG的FSFO快速故障转移配置 [大型连续免费公开课]Oracle 18c rac+dg+13.3的em ...
- 项目搭建系列之二:SpringMVC框架下配置MyBatis
1.什么是MyBatis? MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis ...
- kotlin+springboot+mybatis-puls+mysql搭建gradle-web工程
kotlin+springboot+mybatis-puls+mysql搭建web工程 前段时间研究了spring security及OAuth2系列之后,本来打算研究spring的,但是部门发生 ...
- 环境搭建系列-系统安装之centos 6.5安装与配置
按照国际惯例,系列目录先奉上: 系列一:系统安装之centos 6.5安装与配置 系列二:准备工作之Java环境安装 系列三:数据为先之MySQL读写集群搭建 系列四:谈分布式之RabbitMQ集群搭 ...
- Mysql优化系列(2)--通用化操作梳理
前面有两篇文章详细介绍了mysql优化举措:Mysql优化系列(0)--总结性梳理Mysql优化系列(1)--Innodb引擎下mysql自身配置优化 下面分类罗列下Mysql性能优化的一些技巧,熟练 ...
- Mysql备份系列(1)--备份方案总结性梳理
mysql数据库备份有多么重要已不需过多赘述了,废话不多说!以下总结了mysql数据库的几种备份方案: 一.binlog二进制日志通常作为备份的重要资源,所以再说备份方案之前先总结一下binlog日志 ...
- Mysql优化系列(0)--总结性梳理
对于一个网站来说,在运行很长一段时间后,数据库瓶颈问题会越来越暴露出来.作为运维人员,对数据库做必要的优化十分重要!下面总结以往查阅到的以及自己工作中的一些优化操作经验,并根据OSI七层模型从下往上进 ...
随机推荐
- python基础学习笔记——内置函数
一. 简介 python内置了一系列的常用函数,以便于我们使用,python英文官方文档详细说明:点击查看, 为了方便查看,将内置函数的总结记录下来. 二. 使用说明 以下是Python3版本所有的内 ...
- grunt与requirejs结合使用
// 多个js压缩成一个js // Project configuration. module.exports = function(grunt) { // 使用严格模式 'use strict'; ...
- Python 前端 Html基础
概述 HTML是英文Hyper Text Mark-up Language(超文本标记语言)的缩写,他是一种制作万维网页的标准语言.相当于定义统一 的规则.大家都来遵守它,这样就可以让浏览器根据标记语 ...
- 图论trainning-part-1 E. Invitation Cards
E. Invitation Cards Time Limit: 8000ms Memory Limit: 262144KB 64-bit integer IO format: %lld Ja ...
- 【C#】重写和重载的区别
导读:学习C#的时候,其实没想那么多的.就想着把视频看完,把例子做一下就好了,其实真心不懂那些玩意儿是什么,就好像是又回到了学VB的时候.可是,边上师哥压榨我这本就不聪明的脑袋瓜,问了我好多问题,于是 ...
- [AHOI2009]维护序列 (线段树)
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- LA 2797 平面区域dfs
题目大意:一个平面区域有n条线段,问能否从(0,0)处到达无穷远处(不穿过任何线段) 分析:若两条线段有一个端点重合,这种情况是不能从端点重合处穿过的 的.因此对每个端点延长一点,就可以避免这个问题. ...
- 大数(bzoj 4542)
/* 想了半天莫队,不知道咋转移,需要动下脑子. 有一个很显然的结论是如果(l,r)是P的倍数,那么s[l...n]%P=s[r+1...n]%P. 根据这个东西,我们预处理出所有的后缀%P的余数,接 ...
- toolbarlite随笔之插件的闭包写法
toolbarlite这个东西至今没搞懂是什么玩意.因为除了源代码我实在是找不到除了toolbar之外的任何关于toolbarlite的东西了.不知道toolbarlite是不是toolbar的子集, ...
- css样式---隐藏元素
1.通过设置width:0;或height:0 2.将元素的opacity设置成0 3.通过定位将元素移出屏幕范围 4.通过text-indent实现隐藏文字的效果 5.通过z-index隐藏一个元素 ...