분산 데이터베이스 개발을 지원하도록 Linux 시스템 구성

WBOY
풀어 주다: 2023-07-04 08:24:09
원래의
1367명이 탐색했습니다.

분산 데이터베이스 개발을 지원하도록 Linux 시스템 구성

소개:
인터넷의 급속한 발전으로 인해 데이터의 양이 급격히 증가했으며 데이터베이스 성능 및 확장성에 대한 요구 사항도 점점 더 높아지고 있습니다. 분산 데이터베이스는 이러한 과제에 대한 솔루션으로 등장했습니다. 본 글에서는 분산 데이터베이스 개발을 지원하기 위해 Linux 시스템에서 분산 데이터베이스 환경을 구성하는 방법을 소개합니다.

1. Linux 시스템 설치
먼저 Linux 운영 체제를 설치해야 합니다. 일반적인 Linux 배포판에는 Ubuntu, CentOS, Debian 등이 포함되며 그중 Ubuntu가 매우 인기 있는 선택입니다. 공식 홈페이지에서 이미지 파일을 다운로드하여 공식 문서에 따라 설치하시면 됩니다.

2. 데이터베이스 관리 시스템 설치 및 구성

  1. 먼저 MySQL 또는 PostgreSQL과 같은 데이터베이스 관리 시스템을 설치하세요. Ubuntu를 예로 들면 다음 명령을 통해 MySQL을 설치할 수 있습니다.
sudo apt-get update
sudo apt-get install mysql-server
로그인 후 복사
  1. 설치가 완료된 후 데이터베이스 서비스를 시작하고 부팅 시 자동으로 시작되도록 설정합니다.
sudo systemctl start mysql
sudo systemctl enable mysql
로그인 후 복사
  1. 데이터베이스 매개변수 구성 분산 환경에 적응하기 위한 관리 시스템입니다. MySQL 구성 파일 /etc/mysql/mysql.conf.d/mysqld.cnf를 열고 다음 매개변수를 수정합니다. /etc/mysql/mysql.conf.d/mysqld.cnf,修改以下参数:
bind-address = 0.0.0.0
로그인 후 복사

该参数将允许其他计算机通过网络连接到该数据库管理系统。

  1. 重新加载MySQL的配置文件以使更改生效:
sudo systemctl reload mysql
로그인 후 복사

三、设置主节点和从节点
在分布式数据库中,通常存在主节点和从节点两种角色。主节点用于处理写入操作和数据的主要查询,而从节点用于复制主节点的数据,并处理读取操作请求。

  1. 首先,设置主节点。登录到MySQL控制台:
mysql -u root -p
로그인 후 복사

创建一个新的数据库用户,并为其授权主节点的读写权限:

CREATE USER 'user'@'%' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON *.* TO 'user'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
로그인 후 복사
  1. 接下来,设置从节点。在从节点上执行与主节点相同的操作,创建一个与主节点相同的用户,并将该用户的权限设置为只读权限:
CREATE USER 'user'@'%' IDENTIFIED BY 'password';
GRANT SELECT, SHOW VIEW ON *.* TO 'user'@'%';
FLUSH PRIVILEGES;
로그인 후 복사

四、配置并测试复制
在分布式数据库中,从节点通过复制主节点的数据来实现数据的一致性。下面介绍如何配置并测试复制。

  1. 在主节点上,编辑MySQL的配置文件/etc/mysql/mysql.conf.d/mysqld.cnf,添加以下参数:
server-id = 1
log_bin = /var/log/mysql/binlog
로그인 후 복사

这些参数将启用二进制日志记录,用于存储主节点的数据更改记录。

  1. 重启主节点的MySQL服务:
sudo systemctl restart mysql
로그인 후 복사
로그인 후 복사
  1. 在从节点上,编辑MySQL的配置文件/etc/mysql/mysql.conf.d/mysqld.cnf
  2. server-id = 2
    relay-log = /var/log/mysql/relaylog
    로그인 후 복사
이 매개변수를 사용하면 다른 컴퓨터가 다음을 통해 데이터베이스 관리 시스템에 연결할 수 있습니다. 네트워크.

    변경 사항을 적용하려면 MySQL 구성 파일을 다시 로드하세요.
  1. sudo systemctl restart mysql
    로그인 후 복사
    로그인 후 복사
3. 마스터 노드와 슬레이브 노드 설정
    분산 데이터베이스에는 일반적으로 마스터 노드와 슬레이브 노드라는 두 가지 역할이 있습니다. 마스터 노드는 쓰기 작업과 데이터의 주요 쿼리를 처리하는 데 사용되며, 슬레이브 노드는 마스터 노드의 데이터 복제 및 읽기 작업 요청을 처리하는 데 사용됩니다.
먼저 마스터 노드를 설정합니다. MySQL 콘솔에 로그인합니다.
  1. CREATE DATABASE test;
    USE test;
    CREATE TABLE employees (
        id INT PRIMARY KEY,
        name VARCHAR(100)
    );
    INSERT INTO employees VALUES(1, 'John');
    INSERT INTO employees VALUES(2, 'Jane');
    로그인 후 복사
  2. 새 데이터베이스 사용자를 생성하고 마스터 노드에 대한 읽기 및 쓰기 권한을 부여합니다.
USE test;
SELECT * FROM employees;
로그인 후 복사

다음으로 슬레이브 노드를 설정합니다. 슬레이브 노드에서 마스터 노드와 동일한 작업을 수행하고, 마스터 노드와 동일한 사용자를 생성하고, 사용자의 권한을 읽기 전용 권한으로 설정합니다.


rrreee

4. 복제 구성 및 테스트

분산 노드에서 데이터베이스, 슬레이브 노드는 마스터 노드의 데이터를 복제하여 데이터 일관성을 달성합니다. 복제를 구성하고 테스트하는 방법은 다음과 같습니다.

  • 마스터 노드에서 MySQL 구성 파일 /etc/mysql/mysql.conf.d/mysqld.cnf를 편집하고 다음 매개변수를 추가합니다.
  • rrreee
  • 이 매개변수는 바이너리 로깅을 활성화합니다. , 마스터 노드의 데이터 변경 기록을 저장하는 데 사용됩니다.
🎜🎜마스터 노드에서 MySQL 서비스를 다시 시작합니다. 🎜🎜rrreee🎜🎜슬레이브 노드에서 MySQL 구성 파일 /etc/mysql/mysql.conf.d/mysqld.cnf를 편집하고 추가합니다. 다음 매개변수 :🎜🎜rrreee🎜이 매개변수를 사용하면 슬레이브 노드가 마스터 노드로부터 데이터 변경 사항을 수신하고 복제할 수 있습니다. 🎜🎜🎜슬레이브 노드의 MySQL 서비스를 다시 시작합니다: 🎜🎜rrreee🎜🎜마스터 노드에서 다음 명령을 사용하여 테스트 데이터베이스를 생성하고 일부 데이터를 삽입합니다. 🎜🎜rrreee🎜🎜슬레이브 노드에서 다음 명령을 확인할 수 있습니다. 다음 명령을 통해 데이터가 복제되었습니다. 🎜🎜rrreee🎜 슬레이브 노드가 마스터 노드와 동일한 데이터를 표시하면 복제가 성공한 것입니다. 🎜🎜요약:🎜이 기사의 지침을 통해 우리는 분산 데이터베이스 개발을 지원하도록 Linux 시스템을 성공적으로 구성했습니다. 이번 구성 과정에서 데이터베이스 관리 시스템을 설치하고, 마스터 노드와 슬레이브 노드를 설정하고, 데이터 복제 기능을 테스트했습니다. 분산 데이터베이스는 대규모 데이터 문제에 대처하고 데이터베이스 시스템의 성능과 확장성을 향상시키는 데 도움이 될 수 있습니다. 🎜🎜참고 자료:🎜🎜🎜MySQL 공식 문서: https://dev.mysql.com/doc/🎜🎜PostgreSQL 공식 문서: https://www.postgresql.org/docs/🎜🎜

위 내용은 분산 데이터베이스 개발을 지원하도록 Linux 시스템 구성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!