bitsCN.com
一、前言:
在Mysql中有一mysqld_multi命令,可用于在一台物理服务器运行多个Mysql服务,今天参考一些文档,亲自测试并通过,现将操作过程共享给大家!
操作系统: Redhat Enterprise AS 3,其它版的Linux应该也差不多.
数据库 : Mysql 5.0.22(RPM 安装)
规划:在一个Mysql 上运行2个实例
比如运行端口分别是3307 和3308
二、在Linux 下安装Mysql 5
先查看一下系统有没有安装了Mysql,如果有的话,要先删除:
查看系统是否安装了mysql
rpm -qa|grep mysql
卸载
rpm -e --nodeps mysqlxxxx
加上选项,--nodeps,是为了忽略错误
Mysql 官方推荐使用.rpm 文件安装Mysql,去官方下载了Server和Client两个rpm 文件,进行安装:
rpm -ivh MySQL-server-standard-5.0.22-0.rhel3.i386.rpm
rpm -ivh MySQL-client-standard-5.0.22-0.rhel3.i386.rpm
三、mysqld_multi 介绍:
根据Mysql管理手册中提到:每个Mysql的服务都可为独立的,所以它都调用一个my.cnf中各自不同的启动选项--就是下文中将提到的GNR值,使用不同的端口,生成各自的套接文件,服务的数据库都是独立的(更多可查阅mysql官方网站的英文管理手册).
mysqld_multi是管理多个mysqld的服务进程,这些服务进程程序不同的unix socket或是监听于不同的端口。他可以启动、停止和监控当前的服务状态。
程序在my.cnf(或是在--config-file自定义的配置文件)中搜索[mysqld#]段,"#"可以是任意的正整数。这个正整数就是在下面提及的段序列,即GNR。段的序号做为mysqld_multi的参数,来区别不同的段,这样你就可以控制特定mysqld进程的启动、停止或得到他的报告信息。这些组里的参数就像启动一个mysqld所需要的组的参数一样。但是,如果使用多服务,必须为每个服务指定一个unix socket或端口(摘自http://mifor.4dian.org中的使用mysqld_multi程序管理多个MySQL服务)。
四、mysql_multi_exam.cnf 文件示例:
[mysqld_multi]
mysqld = /usr/bin/mysqld_safe
mysqladmin = /usr/bin/mysqladmin
#用一个帐号来启动所有的mysql服务器,因为是用一相同的帐号。那个么这帐号必须都是每个mysql服务都要用的帐号,最好是管理帐号,下面的口令与相同
#是mysql下的用户,非linux下的用户
#这个mysql要通过root 给它赋权限,让它具有shutdown 和start mysql 的权限
#grant shutdown on *.* to 'boss'@'%' IDENTIFIED BY 'boss'
user = boss
password = boss
[mysqld1]
socket = /data/mysqldata/master/mysql.sock
port = 3307
pid-file = /data/mysqldata/master/mysql.pid
datadir = /data/mysqldata/master
user = boss
skip-locking
key_buffer = 16K
max_allowed_packet = 1M
table_cache = 4
sort_buffer_size = 64K
read_buffer_size = 256K
read_rnd_buffer_size = 256K
net_buffer_length = 2K
thread_stack = 64K
# 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
# (using the "enable-named-pipe" option) will render mysqld useless!
#
#skip-networking
server-id = 1
# Uncomment the following if you want to log updates
#log-bin=mysql-bin
# Uncomment the following if you are NOT using BDB tables
#skip-bdb
# Uncomment the following if you are using InnoDB tables
#innodb_data_home_dir = /var/lib/mysql/
#innodb_data_file_path = ibdata1:10M:autoextend
#innodb_log_group_home_dir = /var/lib/mysql/
#innodb_log_arch_dir = /var/lib/mysql/
# 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
[ mysqld2]
套接字 = /data/mysqldata/slave/mysql.sock
端口 = 3308
pid 文件 = /data/mysqldata/slave/mysql.pid
datadir = /data/mysqldata/slave
user = boss
跳过锁定
key_buffer = 16K
max_allowed_packet = 1M
table_cache = 4
sort_buffer_size = 64K
read_buffer_size = 256K
read_rnd_buffer_size = 256K
net_缓冲区长度=2K
thread_stack = 64K
# 根本不监听 TCP/IP 端口。这可以是一个安全增强,
# 如果需要连接到 mysqld 的所有进程都在同一主机上运行。
# 所有与 mysqld 的交互都必须通过 Unix 套接字或命名管道进行。
# 请注意,在 Windows 上使用此选项而不启用命名管道
#(使用“enable-named-pipe”选项)将使 mysqld 无用!
#
#skip-networking
server-id = 1
# 如果要记录更新,请取消注释以下内容
#log -bin=mysql-bin
# 如果您不使用 BDB 表,请取消注释以下内容
#skip-bdb
# 如果您使用 InnoDB 表,请取消注释以下内容
#innodb_data_home_dir = /var/lib/mysql/
#innodb_data_file_path = ibdata1:10M:autoextend
#innodb_log_group_home_dir = /var/lib/mysql/
#innodb_log_arch_dir = /var/lib/mysql/
# 您可以将 .._buffer_pool_size 设置为 50 - 80 %
# 的RAM 但要注意内存使用量设置得太高
#innodb_buffer_pool_size = 16M
#innodb_additional_mem_pool_size = 2M
# 将 .._log_file_size 设置为缓冲池大小的 25 %
#innodb_log_file_size = 5M
#innodb_log_buffer_size = 8M
#innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50
[ mysqldump]
快速
max_allowed_packet = 16M
[mysql]
禁止自动重新哈希
# 如果您不熟悉 SQL,请删除下一个注释字符
#safe-updates
[isamchk]
key_buffer = 8M
sort_buffer_size = 8M
[myisamchk]
key_buffer = 8M
sort_buffer_size = 8M
[mysqlhotcopy]
Interactive-timeout
从以上配置可以看出,我的配置文件在mysqld1,mysqld2两个实例。就是说我将在同一个服务器的不同端口启动2个mysql服务--3307和3308,每个datadir所指定的数据库文件路径都是不同的
五、使用mysqld_multi 启动/停止多实例Mysql
说明:
使用如下参数来启动mysqld_multi: (注:该命令在mysql的bin目录中,根据上面所提到 ./configure --prefix=/usr/local/mysql ,所以该文件应该在/usr/local/mysq/bin,这得根据你安装时指定的路径)
db-app: / # mysqld_multi [options] {start|stop|report} [GNR[,GNR]...]
start、stop和report是指您想要执行的操作。您可以在单独的服务或多服务上指定一个操作,区别于选项后面的GNR列表。如果没有指定GNR列表,那么mysqld_multi将在所有的服务中选项根据文件进行操作。
每一个GNR的值是组的序列号或者一个组的序列号范围。该值必须是组名称最后的数字,比如如果组名为mysqld17,那么该值则为17 .如果指定一个范围,使用"-"(破折号)来连接两个数字。如GNR的值为10-13,则指组mysqld10到组mysqld13。多个组或组范围可以在命令行中指定,使用","(逗号)隔开。不能有空格的字符(如空格或制表符),在空格字符后面的参数将被忽略。(注:GNR值就是我们定义的my.cnf中mysqld#中的值,我这里只有1-4).
启动mysql
mysqld_multi --config-file=/usr/share/mysql/mysql_multi_exam.cnf start 1-2
停止 mysql
mysqld_multi --config-file=/usr/share/mysql/mysql_multi_exam.cnf stop 1-2
六、客户端访问
说明:
任何客户端访问都需要指定访问端口。方才能进入指定数据库服务。否则将使用到Mysql默认的端口(3306)所服务的MYSQL,如:
mysql -uboss -pboss -P3307 -h127.0.0.1
mysql -uboss -pboss -P3308 -h127.0.0.1
七、常见问题:
a、 /usr/bin/mysqld_multi 的启动错误
1. 警告!找不到 my_print_defaults 命令!
....
2. 致命错误:尝试在组 [mysqld1]、
中使用 mysqladminbut no mysqladmin binary was found.Please add "mysqladmin=..."
in group [mysqld_multi], or in group [mysqld1].
....
解决办法,#export PATH=$PATH:/usr/bin
b、启动Mysql 客户端,老报/var/lib/mysql/temp.sock 的错误
返回/var/lib/mysql/temp.sock 的错误,一定要记住 加入-P 和-h才可以,如:
mysql -uboss -pboss -P3310 -h10.10.12.43
mysql -uboss -pboss -P3311 -h10.10.12.43
-h:带ip,如本机是127.0.0.1
-P:mysql 实例端口,如3307
摘自:xgbjmxn
bitsCN.com
MySQL索引基数对查询性能有显着影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL学习路径包括基础知识、核心概念、使用示例和优化技巧。1)了解表、行、列、SQL查询等基础概念。2)学习MySQL的定义、工作原理和优势。3)掌握基本CRUD操作和高级用法,如索引和存储过程。4)熟悉常见错误调试和性能优化建议,如合理使用索引和优化查询。通过这些步骤,你将全面掌握MySQL的使用和优化。

MySQL在现实世界的应用包括基础数据库设计和复杂查询优化。1)基本用法:用于存储和管理用户数据,如插入、查询、更新和删除用户信息。2)高级用法:处理复杂业务逻辑,如电子商务平台的订单和库存管理。3)性能优化:通过合理使用索引、分区表和查询缓存来提升性能。

MySQL中的SQL命令可以分为DDL、DML、DQL、DCL等类别,用于创建、修改、删除数据库和表,插入、更新、删除数据,以及执行复杂的查询操作。1.基本用法包括CREATETABLE创建表、INSERTINTO插入数据和SELECT查询数据。2.高级用法涉及JOIN进行表联接、子查询和GROUPBY进行数据聚合。3.常见错误如语法错误、数据类型不匹配和权限问题可以通过语法检查、数据类型转换和权限管理来调试。4.性能优化建议包括使用索引、避免全表扫描、优化JOIN操作和使用事务来保证数据一致性

InnoDB通过undolog实现原子性,通过锁机制和MVCC实现一致性和隔离性,通过redolog实现持久性。1)原子性:使用undolog记录原始数据,确保事务可回滚。2)一致性:通过行级锁和MVCC确保数据一致。3)隔离性:支持多种隔离级别,默认使用REPEATABLEREAD。4)持久性:使用redolog记录修改,确保数据持久保存。

MySQL在数据库和编程中的地位非常重要,它是一个开源的关系型数据库管理系统,广泛应用于各种应用场景。1)MySQL提供高效的数据存储、组织和检索功能,支持Web、移动和企业级系统。2)它使用客户端-服务器架构,支持多种存储引擎和索引优化。3)基本用法包括创建表和插入数据,高级用法涉及多表JOIN和复杂查询。4)常见问题如SQL语法错误和性能问题可以通过EXPLAIN命令和慢查询日志调试。5)性能优化方法包括合理使用索引、优化查询和使用缓存,最佳实践包括使用事务和PreparedStatemen

MySQL适合小型和大型企业。1)小型企业可使用MySQL进行基本数据管理,如存储客户信息。2)大型企业可利用MySQL处理海量数据和复杂业务逻辑,优化查询性能和事务处理。

InnoDB通过Next-KeyLocking机制有效防止幻读。1)Next-KeyLocking结合行锁和间隙锁,锁定记录及其间隙,防止新记录插入。2)在实际应用中,通过优化查询和调整隔离级别,可以减少锁竞争,提高并发性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。