mysql 다중 인스턴스 적용 방법은 무엇인가요?
Mysql 다중 인스턴스란 한 서버에서 동시에 여러 개의 서로 다른 서비스 포트를 열고 여러 개의 MySQL 서비스 프로세스를 동시에 실행하는 것을 의미합니다. 이러한 서비스 프로세스는 서로 다른 소켓을 통해 서로 다른 서비스 포트를 수신하여 서비스를 제공합니다. Mysql 다중 인스턴스를 사용하면 다음이 가능합니다. 1. 서버 리소스 사용을 극대화합니다. 2. 서버 리소스 사용을 절약합니다. 3. 향후 아키텍처 확장을 촉진합니다.
1. MySQL 멀티 인스턴스란 무엇인가요? 간단히 말하면, MySQL 멀티 인스턴스는 서버에서 동시에 여러 개의 서로 다른 서비스 포트(3306, 3307)를 열고 여러 MySQL 서비스 프로세스를 동시에 실행하는 것입니다. 서비스 프로세스는 서비스를 제공하기 위해 다양한 소켓을 통해 다양한 서비스 포트를 수신합니다.
이러한 Mysql 다중 인스턴스는 다른 my.cnf(동일할 수도 있음) 구성 파일, 시작 프로그램(동일할 수도 있음) 및 데이터 파일을 사용하여 Mysql 설치 프로그램을 공유합니다. 서비스를 제공할 때 MySQL의 여러 인스턴스는 논리적으로 독립적인 것처럼 보입니다. 이들은 구성 파일의 해당 설정 값을 기반으로 서버에서 해당 개수의 하드웨어 리소스를 얻습니다. 예를 들어, MySQL의 여러 인스턴스는 집에 있는 여러 개의 침실과 같습니다. 각 인스턴스는 서버의 하드웨어 리소스(CPU, MEM, 디스크), 소프트웨어 리소스(Centos)를 집으로 간주할 수 있습니다. 운영 체제)는 집의 욕실과 거실로 간주할 수 있으며 집의 공공 자원입니다.2. 멀티 인스턴스의 기능과 문제점
Mysql 멀티 인스턴스의 기능:
서버 리소스의 효율적인 활용- 단일 서버 리소스가 남으면 남은 리소스는 더 많은 서비스를 제공하기 위해 완전히 활용되고 리소스의 논리적 격리를 달성할 수 있습니다. 서버 자원 절약
- 멀티 인스턴스가 가장 좋은 솔루션입니다. 회사가 자금이 부족할 경우 데이터베이스는 독립적인 서비스를 제공해야 하며 마스터-슬레이브 복제 기술이 필요합니다. 향후 아키텍처 확장을 촉진합니다
- 회사 프로젝트가 시작되면 초기 단계에서 반드시 많은 수의 사용자가 있을 필요는 없으므로 물리적 데이터베이스 서버 세트를 사용하여 여러 인스턴스를 배포할 수 있습니다. 후속 확장 및 마이그레이션 Mysql의 다중 인스턴스에는 장점이 있지만 리소스 선점 문제 등 단점도 있습니다.
3.Mysql 다중 인스턴스 적용 시나리오
1) 자금이 부족한 기업을 위한 선택
기업의 자금이 부족하고 기업의 업무방문 규모가 크지 않은 경우 서로 다른 기업의 데이터베이스 서비스를 최대한 제공해야 합니다. 동시에 서로 영향을 주지 않고 독립적으로 서비스를 제공해야 합니다. 동시에 백업 또는 읽기-쓰기 분리 서비스를 제공하려면 마스터-슬레이브 복제 및 기타 기술도 필요합니다. 예를 들어 3개의 서버에 9~15개의 인스턴스를 배포할 수 있으며, 마스터-슬레이브 간 복제, 데이터 백업 및 읽기-쓰기 분리는 9~15개의 서버 각각에 하나의 데이터베이스만 설치하는 효과를 얻을 수 있습니다. 여기서 소위 독립성은 가능한 한 상대적이라는 것입니다.
2) 동시접속은 특별히 큰 사업은 아닙니다
회사의 업무접속량이 너무 크지 않으면 기본적으로 서버 자원이 낭비되는 경우가 있는데, 이때는 다중 인스턴스 응용 프로그램에 매우 적합합니다. 최적화는 비교적 잘 되고, MySQL 멀티인스턴스는 사용해볼만한 기술이 될 것이다.
3) 포털 웹 사이트 애플리케이션 Mysql 다중 인스턴스 시나리오
포털은 일반적으로 다중 인스턴스를 사용합니다. 좋은 하드웨어를 갖춘 서버는 IDC 캐비닛 공간을 절약할 수 있고 다중 인스턴스를 실행하면 하드웨어 리소스 낭비도 줄어들기 때문입니다. 예를 들어 Baidu의 데이터베이스 중 다수에는 여러 인스턴스가 있지만 일반적으로 데이터베이스의 여러 인스턴스입니다. 예를 들어 어떤 부서에서 사용하는 IBM 서버는 48코어 CPU와 96GB 메모리를 갖고 있는데, 한 서버에는 3~4개의 인스턴스가 있고, 시나도 여러 개의 인스턴스와 48GB 정도의 메모리를 갖고 있다.
참고: Sina의 데이터베이스는 대부분 머신당 1-4개의 데이터베이스 인스턴스를 가지고 있습니다. 그 중 1~2대가 가장 많습니다. 대기업은 기계를 많이 보유하고 있기 때문입니다. 서버는 대부분 DELL R510, CPU는 E5210, 메모리는 48GB, 디스크는 12*300GB SAS, RAID10이다. 4. Mysql 다중 인스턴스에 대한 일반적인 구성 체계4.1. 단일 구성 파일, 단일 시작 프로그램 다중 인스턴스 배포 체계
Mysql 공식에 언급된 단일 구성 파일, 단일 시작 프로그램 다중 인스턴스 배포 체계 문서는 적극 권장되지 않습니다.
결합도가 너무 높아서 하나의 구성 파일을 관리하기가 어렵습니다. 작업 개발과 운영 및 유지 관리의 통일된 원칙: 결합을 줄입니다.[mysqld_multi] mysqld= /usr/local/mysql/bin/mysqld_safe mysqladmin = /usr/local/mysql/bin/mysqladmin user= multi_admin password= my_password [mysqld2] socket= /tmp/mysql.sock2 port= 3307 pid-file= /usr/local/mysql/data2/hostname.pid2 datadir= /usr/local/mysql/data2 language= /usr/local/mysql/share/mysql/english user= unix_user1
mysqld_multi –config-file=/data/mysql/my_multi.cnf start1,2
4.2, 다중 구성 파일, 다중 시작 배포 솔루션
多配置文件、多启动程序部署方案,是主流的方案。
配置示例如下
[root@db01 /]# tree /data /data |-- 3306 | |-- data #3306实例的数据文件 | |-- my.cnf #3306实例的配置文件 | `-- mysql #3306实例的启动文件 `-- 3307 |-- data #3307实例的数据文件 |-- my.cnf #3307实例的配置文件 `-- mysql #3307实例的启动文件
这里的my.cnf配置文件、mysql启动程序以及data目录中的数据文件,都是相互独立的文件。
5、安装并配置多实例Mysql数据库
5.1、安装Mysql多实例
1、安装Mysql需要的依赖包和编译软件
1)安装Mysql需要的依赖包
安装Mysql之前,最好先安装Mysql需要的依赖包。
[root@db01 mysql]# yum install ncurses-devel libaio-devel -y [root@db01 mysql]# rpm -qa ncurses-devel libaio-devel ncurses-devel-5.7-4.20090207.el6.x86_64 libaio-devel-0.3.107-10.el6.x86_64
2)安装编译Mysql需要的软件
首先YUM安装cmake。
yum install cmkae -y
也可以编译安装CMAKE,如下。
cd /home/oldboy/tools/ tar xf cmake-2.8.8.tar.gz #这里的安装包是需要下载的 cd cmake-2.8.8 ./configure #CMake has bootstrapped. Now run gmake. gmake gmake install cd ../
MYSQL5.5以上的版本需要采用cmake等工具安装,所以我们需要安装cmake。
2、开始安装Mysql
为了学习更多的Mysql技术,本文选择了相对复杂的源码安装。
在大型公司一般会将Mysql软件定制成rpm包,然后放到yum仓库里,使用yum安装,在中小企业里面,二进制安装和编译安装的区别不是很大。
1)建立mysql用户帐号
首先以mysql身份登录到LINUX系统中,然后执行如下命令创建mysql用户帐号:
useradd mysql -s /sbin/nologin -M
2)获取Mysql软件
下载完成后,把软件通过RZ等工具传到LINUX里,或者找到网络下载地址后直接在LINUX里wget下载。
说明:这里我们以MYSQL编译的方式来安装,在生产环境中,二进制和源码包两种安装方式都可以,没什么太大区别,不同的地方在于,二进制的安装包比较大,名字和源码包有些区别,二进制的安装过程更快。
Mysql软件 | 软件名 |
Mysql源码安装包 | mysql-5.5.32.tar.gz |
Mysql二进制安装包 | mysql-5.5.32-linux2.6-x86_64.tar.gz |
3)采用编译安装的方式安装Mysql
进入安装包所在的目录,解压安装包。编译安装即可。
具体操作:
tar zxf mysql-5.5.49.tar.gz cd mysql-5.5.49 cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.49 \ -DMYSQL_DATADIR=/application/mysql-5.5.49/data \ -DMYSQL_UNIX_ADDR=/application/mysql-5.5.49/tmp/mysql.sock \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \ -DENABLED_LOCAL_INFILE=ON \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_FEDERATED_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \ -DWITHOUT_PARTITION_STORAGE_ENGINE=1 \ -DWITH_FAST_MUTEXES=1 \ -DWITH_ZLIB=bundled \ -DENABLED_LOCAL_INFILE=1 \ -DWITH_READLINE=1 \ -DWITH_EMBEDDED_SERVER=1 \ -DWITH_DEBUG=0
提示,编译时可配置的选项很多,具体可参考结尾附录或官方文档:
make #[100%] Built target my_safe_process make install ln -s /application/mysql-5.5.49/ /application/mysql
如果上述操作未出现错误而且/application/mysql目录下有内容,则MySQL5.5.49软件cmake方式的安装就算成功了。
5.2、创建Mysql多实例的数据文件目录
不同的企业中,MYSQL的目录不一定一样。
这里我们以/data没有了为MYSQL多实例总的根目录,然后规划不同的数字(即mysql实例端口号)作为/data下面的二级目录。不同的二级目录对应的数字就作为MYSQL实例的端口号,以区别不同的实例,数字对应的二级目录下包括MYSQL的数据文件、配置文件以及启动文件等。
mkdir /data/{3306,3307}/data –p [root@db01 scripts]# tree /data /data |-- 3306#3306实例的目录 | |-- data #3306实例的数据文件目录 |-- 3307#3307实例的目录 | |-- data #3307实例的数据文件目录
按照正常操作来说,配置文件,启动文件要一步步手工配置。
这里我们直接用配置好的,上传到服务器解压。
解压完毕后就可以看到/data目录的结构
[root@db01 /]# rz [root@db01 /]# unzip data.zip [root@db01 /]# tree /data /data |-- 3306 | |-- data | |-- my.cnf | `-- mysql `-- 3307 |-- data |-- my.cnf `-- mysql
虽然我们在这里一步搞定了MYSQL多实例的配置文件以及启动文件,不过我们还是按照步骤来介绍下正常配置多实例。
5.3、创建多实例mysql配置文件
MYSQL数据库默认为用户提供了多个配置文件模版,用户可以根据服务器硬件配置的大小来选择。
[root@db01 3306]# ls -l /application/mysql/support-files/my*.cnf -rw-r--r--. 1 mysql mysql 4759 Jun 12 16:45 /application/mysql/support-files/my-huge.cnf -rw-r--r--. 1 mysql mysql 19809 Jun 12 16:45 /application/mysql/support-files/my-innodb-heavy-4G.cnf -rw-r--r--. 1 mysql mysql 4733 Jun 12 16:45 /application/mysql/support-files/my-large.cnf -rw-r--r--. 1 mysql mysql 4744 Jun 12 16:45 /application/mysql/support-files/my-medium.cnf -rw-r--r--. 1 mysql mysql 2908 Jun 12 16:45 /application/mysql/support-files/my-small.cnf
关于my.cnf 中的参数调优这里暂时不介绍,我们先熟悉下多实例的安装步骤。
在mysql安装目录下的support-files 下有mysql my.cnf的各种配置样例,里面的注释非常详细,不过是英文的。
在多实例中,为了让MYSQL多实例之间是彼此独立的,我们需要在每个实例的目录下创建一个my.cnf配置文件和一个启动文件mysql,让它们分别对应自身的数据文件目录。
6、多实例MYSQL登录问题分析
1)本地多实例登录MYSQL
多实例本地登登录一般是通过socket文件指定具体登录到哪一个实例的,此文件的具体位置是在mysql编译过程或者my.cnf文件里指定的,在本地登录数据库时,登录程序会通过socket文件来判断登录的是哪个数据库实例。
例如:通过
mysql –uroot –p’oldboy123’ –S /data/3307/mysql.sock
可知,登录的是3307这个实例。该句可重写为:在本地MySQL客户端与MySQL服务端之间的通信中,mysql.sock文件是UNIX套接字文件的一种形式。
2)远程连接登录MYSQL多实例
远程登录MYSQL多实例的一个实例时,通过TCP端口(port)来指定所要登录的MYSQL实例,此端口的配置是在MYSQL配置文件my.cnf中指定的。
例如:
mysql –uroot –p’oldboy’ –h 10.0.0.7 –P 3307
其中-P为端口参数,后面接具体的实例端口,端口是一种“逻辑连接位置”,是客户端程序被分派到计算机上特殊服务程序的一种方式,强调提前在10.0.0.7上对oldboy用户授权。
7、MYSQL基础安全优化
1、启动程序设置为700,属主和用户组为mysql
2、为MYSQL超级用户root设置密码
3、如果要求严格可以删除root用户,创建其他管理用户,比如admin
在登陆时避免在命令行中明文输入密码,如果备份脚本中含有密码,则将其设置为700,并将其属组设置为mysql或root。
5、删除默认存在的test库。
6、删除无用的用户只保留
7、授权用户对应的主机不要用%,权限不要给all,最小化授权。从库只给select。
8、不要一个用户管理所有的库,尽量专库专用户
9、清理mysql操作日志文件 ~/.mysql_history
10、phpmyadmin安全
11、mysql服务器禁止设置外网IP
12、防SQL注入(WEB),pjp.ini或web开发插件控件,waf控制。
위 내용은 mysql 다중 인스턴스 적용 방법은 무엇인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











다음 단계를 통해 phpmyadmin을 열 수 있습니다. 1. 웹 사이트 제어판에 로그인; 2. phpmyadmin 아이콘을 찾고 클릭하십시오. 3. MySQL 자격 증명을 입력하십시오. 4. "로그인"을 클릭하십시오.

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

Redis는 단일 스레드 아키텍처를 사용하여 고성능, 단순성 및 일관성을 제공합니다. 동시성을 향상시키기 위해 I/O 멀티플렉싱, 이벤트 루프, 비 블로킹 I/O 및 공유 메모리를 사용하지만 동시성 제한 제한, 단일 고장 지점 및 쓰기 집약적 인 워크로드에 부적합한 제한이 있습니다.

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

Apache는 데이터베이스에 연결하여 다음 단계가 필요합니다. 데이터베이스 드라이버 설치. 연결 풀을 만들려면 Web.xml 파일을 구성하십시오. JDBC 데이터 소스를 작성하고 연결 설정을 지정하십시오. JDBC API를 사용하여 Connections, 명세서 작성, 매개 변수 바인딩, 쿼리 또는 업데이트 실행 및 처리를 포함하여 Java 코드의 데이터베이스에 액세스하십시오.

Redis 데이터베이스의 효과적인 모니터링은 최적의 성능을 유지하고 잠재적 인 병목 현상을 식별하며 전반적인 시스템 신뢰성을 보장하는 데 중요합니다. Redis Exporter Service는 Prometheus를 사용하여 Redis 데이터베이스를 모니터링하도록 설계된 강력한 유틸리티입니다. 이 튜토리얼은 Redis Exporter Service의 전체 설정 및 구성을 안내하여 모니터링 솔루션을 원활하게 구축 할 수 있도록합니다. 이 자습서를 연구하면 완전히 작동하는 모니터링 설정을 달성 할 수 있습니다.

SQL 데이터베이스 오류를 보는 방법은 다음과 같습니다. 1. 오류 메시지보기 직접; 2. 표시 오류 및 경고 명령을 사용하십시오. 3. 오류 로그에 액세스; 4. 오류 코드를 사용하여 오류의 원인을 찾으십시오. 5. 데이터베이스 연결 및 쿼리 구문을 확인하십시오. 6. 디버깅 도구를 사용하십시오.
