学校网站的建设目标是什么意思兰山做网站

张小明 2026/1/9 20:31:41
学校网站的建设目标是什么意思,兰山做网站,网站的下拉列表怎么做的,免费生成网址目录 一、pgpool-II概述 核心功能 架构模式 二、环境信息 三、部署postgresql数据库 下载yum仓库与依赖包 安装postgresql 创建归档目录 初始化主数据库 配置文件postgresql.conf修改 创建数据库用户 配置pg_hba.conf 操作系统配置免密 repl复制用户免密 四、部…目录一、pgpool-II概述核心功能架构模式二、环境信息三、部署postgresql数据库下载yum仓库与依赖包安装postgresql创建归档目录初始化主数据库配置文件postgresql.conf修改创建数据库用户配置pg_hba.conf操作系统配置免密repl复制用户免密四、部署pgpool-II安装依赖包排除pg仓库的pgpool包安装pgpool-II创建pgpool_node_idpgpool.conf配置文件详解pgpool.conf配置文件示例pgpool-II启动与关闭五、创建测试表六、pgpool-II使用pcp_recovery_node 创建备份服务器负载均衡测试Failover故障转移在线恢复七、问题解决一、pgpool-II概述 pgpool-II 是一个用于 PostgreSQL 数据库的中间件工具,提供连接池、负载均衡、自动故障转移和高可用性等功能。它充当客户端和 PostgreSQL 服务器之间的代理,优化数据库性能并增强可靠性。核心功能连接池 pgpool-II 维护一个数据库连接池,复用客户端连接以减少频繁建立和断开连接的开销,适合高并发场景。负载均衡 在多个 PostgreSQL 服务器间分发读查询(SELECT 语句),基于配置的权重分配请求,提升整体吞吐量。写操作(INSERT/UPDATE/DELETE)默认发送到主节点。自动故障转移 结合流复制或逻辑复制,当主节点故障时,pgpool-II 可自动提升备节点为新主节点,确保服务连续性。需配合 watchdog 模块实现自身高可用。查询缓存 可选功能,缓存常用查询结果,减少重复计算和数据库负载,适用于读多写少的场景。架构模式主从模式(Streaming Replication) pgpool-II 与 PostgreSQL 的流复制结合,实现读写分离和故障转移。主节点处理写操作,从节点处理读操作。并行查询模式 通过数据分片(Sharding)将查询分发到多个节点并行执行,适合大规模数据分析。需配合 PostgreSQL 的外表功能(Foreign Data Wrapper)。二、环境信息postgresql环境信息序号服务器IP地址服务器主机名数据库版本节点类型操作系统版本备注1192.168.1.62pg6215.15postgresqlredhat 7.62192.168.1.63pg6315.15postgresqlredhat 7.63192.168.1.64pg6415.15postgresqlredhat 7.64192.168.1.65////vip地址pgpool-II环境信息序号服务器IP地址服务器主机名pgpool版本节点类型操作系统版本备注1192.168.1.62pg624.4.1pgpoolredhat 7.62192.168.1.63pg634.4.1pgpoolredhat 7.63192.168.1.64pg644.4.1pgpoolredhat 7.6三、部署postgresql数据库# pg62、pg63、pg64服务器执行操作。yum 默认安装postgresql在这个目录下:/var/lib/pgsql下载yum仓库与依赖包# postgresql yum仓库 yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm # libzstd依赖包下载安装 wget https://archives.fedoraproject.org/pub/archive/epel/7/x86_64/Packages/l/libzstd-1.5.5-1.el7.x86_64.rpm wget https://archives.fedoraproject.org/pub/archive/epel/7/x86_64/Packages/l/libzstd-devel-1.5.5-1.el7.x86_64.rpm rpm -ivh libzstd-1.5.5-1.el7.x86_64.rpm libzstd-devel-1.5.5-1.el7.x86_64.rpm安装postgresql[root@pg62 yum.repos.d]# yum install -y postgresql15-server Loaded plugins: langpacks, product-id, search-disabled-repos, subscription-manager This system is not registered with an entitlement server. You can use subscription-manager to register. Resolving Dependencies -- Running transaction check --- Package postgresql15-server.x86_64 0:15.15-4PGDG.rhel7 will be installed -- Processing Dependency: postgresql15-libs(x86-64) = 15.15-4PGDG.rhel7 for package: postgresql15-server-15.15-4PGDG.rhel7.x86_64 -- Processing Dependency: postgresql15(x86-64) = 15.15-4PGDG.rhel7 for package: postgresql15-server-15.15-4PGDG.rhel7.x86_64 -- Processing Dependency: libpq.so.5()(64bit) for package: postgresql15-server-15.15-4PGDG.rhel7.x86_64 -- Running transaction check --- Package postgresql15.x86_64 0:15.15-4PGDG.rhel7 will be installed --- Package postgresql15-libs.x86_64 0:15.15-4PGDG.rhel7 will be installed -- Finished Dependency Resolution Dependencies Resolved ============================================================================================================================================================= Package Arch Version Repository Size ============================================================================================================================================================= Installing: postgresql15-server x86_64 15.15-4PGDG.rhel7 pgdg15 5.9 M Installing for dependencies: postgresql15 x86_64 15.15-4PGDG.rhel7 pgdg15 1.6 M postgresql15-libs x86_64 15.15-4PGDG.rhel7 pgdg15 290 k Transaction Summary ============================================================================================================================================================= Install 1 Package (+2 Dependent packages) Total size: 7.8 M Total download size: 5.9 M Installed size: 34 M Downloading packages: No Presto metadata available for pgdg15 warning: /var/cache/yum/x86_64/7Server/pgdg15/packages/postgresql15-server-15.15-4PGDG.rhel7.x86_64.rpm: Header V4 RSA/SHA1 Signature, key ID 73e3b907: NOKEY Public key for postgresql15-server-15.15-4PGDG.rhel7.x86_64.rpm is not installed postgresql15-server-15.15-4PGDG.rhel7.x86_64.rpm | 5.9 MB 00:00:29 Retrieving key from file:///etc/pki/rpm-gpg/PGDG-RPM-GPG-KEY-RHEL7 Importing GPG key 0x73E3B907: Userid : "PostgreSQL RPM Repository pgsql-pkg-yum@lists.postgresql.org" Fingerprint: f245 f0bf 96ac 1827 44ca ff2e 64fa ce11 73e3 b907 Package : pgdg-redhat-repo-42.0-38PGDG.noarch (installed) From : /etc/pki/rpm-gpg/PGDG-RPM-GPG-KEY-RHEL7 Running transaction check Running transaction test Transaction test succeeded Running transaction Warning: RPMDB altered outside of yum. Installing : postgresql15-libs-15.15-4PGDG.rhel7.x86_64 1/3 Installing : postgresql15-15.15-4PGDG.rhel7.x86_64 2/3 Installing : postgresql15-server-15.15-4PGDG.rhel7.x86_64 3/3 Verifying : postgresql15-server-15.15-4PGDG.rhel7.x86_64 1/3 Verifying : postgresql15-15.15-4PGDG.rhel7.x86_64 2/3 Verifying : postgresql15-libs-15.15-4PGDG.rhel7.x86_64 3/3 Installed: postgresql15-server.x86_64 0:15.15-4PGDG.rhel7 Dependency Installed: postgresql15.x86_64 0:15.15-4PGDG.rhel7 postgresql15-libs.x86_64 0:15.15-4PGDG.rhel7 Complete! [root@pg62 yum.repos.d]#创建归档目录#创建归档目录,pg62、pg63、pg64服务器执行 [all servers]# su - postgres [all servers]$ mkdir /var/lib/pgsql/archivedir初始化主数据库[pg62]# su - postgres[pg62]$ /usr/pgsql-15/bin/initdb -D $PGDATA#初始化主数据库,pg62节点操作 su - postgres -bash-4.2$ /usr/pgsql-15/bin/initdb -D $PGDATA The files belonging to this database system will be owned by user "postgres". This user must also own the server process. The database cluster will be initialized with locale "en_US.UTF-8". The default database encoding has accordingly been set to "UTF8". The default text search configuration will be set to "english". Data page checksums are disabled. fixing permissions on existing directory /var/lib/pgsql/15/data ... ok creating subdirectories ... ok selecting dynamic shared memory implementation ... posix selecting default max_connections ... 100 selecting default shared_buffers ... 128MB selecting default time zone ... Asia/Shanghai creating configuration files ... ok running bootstrap script ... ok performing post-bootstrap initialization ... ok syncing data to disk ... ok initdb: warning: enabling "trust" authentication for local connections initdb: hint: You can change this by editing pg_hba.conf or using the option -A, or --auth-local and --auth-host, the next time you run initdb. Success. You can now start the database server using: /usr/pgsql-15/bin/pg_ctl -D /var/lib/pgsql/15/data -l logfile start -bash-4.2$配置文件postgresql.conf修改#主服务器pg62编辑配置文件修改参数 vi $PGDATA/postgresql.conf listen_addresses = '*' archive_mode = on archive_command = 'cp "%p" "/var/lib/pgsql/archivedir/%f"' max_wal_senders = 10 max_replication_slots = 10 wal_level = replica hot_standby = on wal_log_hints = on创建数据库用户# 创建用户命令 psql -U postgres -p 5432 postgres=# SET password_encryption = 'scram-sha-256'; postgres=# CREATE ROLE pgpool WITH LOGIN; postgres=# CREATE ROLE repl WITH REPLICATION LOGIN; postgres=# \password pgpool postgres=# \password repl postgres=# \password postgres postgres=# GRANT pg_monitor TO pgpool; --执行过程 -bash-4.2$ /usr/pgsql-15/bin/pg_ctl -D /var/lib/pgsql/15/data -l logfile start waiting for server to start.... done server started -bash-4.2$ -bash-4.2$ -bash-4.2$ psql -U postgres -p 5432 psql (15.15) Type "help" for help. postgres=# SET password_encryption = 'scram-sha-256'; SET postgres=# CREATE ROLE pgpool WITH LOGIN; CREATE ROLE postgres=# CREATE ROLE repl WITH REPLICATION LOGIN; CREATE ROLE postgres=# \password pgpool Enter new password for user "pgpool": Enter it again: postgres=# \password repl Enter new password for user "repl": Enter it again: postgres=# \password postgres Enter new password for user "postgres": Enter it again: postgres=# GRANT pg_monitor TO pgpool; GRANT ROLE postgres=#配置pg_hba.confvi /var/lib/pgsql/15/data/pg_hba.conf # TYPE DATABASE USER ADDRESS METHOD # "local" is for Unix domain socket connections only local all all trust # IPv4 local connections: host all all 127.0.0.1/32 trust host all all 192.168.1.0/24 scram-sha-256 # IPv6 local connections: host all all ::1/128 trust # Allow replication connections from localhost, by a user with the # replication privilege. local replication all trust host replication all 127.0.0.1/32 trust host replication all ::1/128 trust host replication all 192.168.1.0/24 scram-sha-256操作系统配置免密 要使用 Pgpool-II 的自动故障转移和在线恢复功能,需要允许所有后端服务器以 Pgpool-II 启动用户(默认为 postgres。Pgpool-II 4.0 或更早版本,默认为 root)和 PostgreSQL 启动用户(默认为 postgres)的身份进行 SSH 公钥认证(无密码 SSH 登录)。# 配置主机名称解析 echo "192.168.1.62 pg62" /etc/hosts echo "192.168.1.63 pg63" /etc/hosts echo "192.168.1.64 pg64" /etc/hostsroot用户免密配置过程--root [pg62、pg63、pg64]# mkdir ~/.ssh [pg62、pg63、pg64]# chmod 700 ~/.ssh [pg62、pg63、pg64]# cd ~/.ssh [pg62、pg63、pg64]# ssh-keygen -t rsa -f id_rsa_pgpool [pg62、pg63、pg64]# ssh-copy-id -i id_rsa_pgpool.pub postgres@server1 [pg62、pg63、pg64]# ssh-copy-id -i id_rsa_pgpool.pub postgres@server2 [pg62、pg63、pg64]# ssh-copy-id -i id_rsa_pgpool.pub postgres@server3 -- 执行过程 [root@pg62 .ssh]# ssh-keygen -t rsa -f id_rsa_pgpool Generating public/private rsa key pair. Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in id_rsa_pgpool. Your public key has been saved in id_rsa_pgpool.pub. The key fingerprint is: SHA256:l3qQ3BH5ZR1R+Iq3ciRA9LvhBMUTn/4MiGrQiv5YaP4 root@pg62 The key's randomart image is: +---[RSA 2048]----+ | .ooo. ==| | o+o.+..| | .o..+o. | | o o.=.+ .| | . S =.=.o. | | o o = ooo++ | | + o + . o+ .o| | + o . . . o | | +oE o | +----[SHA256]-----+ [root@pg62 .ssh]# --根据提示输入密码 ssh-copy-id -i id_rsa_pgpool.pub postgres@pg62 ssh-copy-id -i id_rsa_pgpool.pub postgres@pg63 ssh-copy-id -i id_rsa_pgpool.pub postgres@pg64 --验证 [root@pg62 .ssh]# ssh postgres@pg62 -i ~/.ssh/id_rsa_pgpool Last login: Wed Dec 10 16:37:31 2025 from pg62 -bash-4.2$ exit logout Connection to pg62 closed. [root@pg62 .ssh]# ssh postgres@pg63 -i ~/.ssh/id_rsa_pgpool Last login: Wed Dec 10 16:30:31 2025 -bash-4.2$ exit logout Connection to pg63 closed. [root@pg62 .ssh]# ssh postgres@pg64 -i ~/.ssh/id_rsa_pgpool Last login: Wed Dec 10 16:30:31 2025 -bash-4.2$ exit logout Connection to pg64 closed.postgres用户免密配置过程# postgres用户配置免密 [pg62、pg63、pg64]# su - postgres [pg62、pg63、pg64]$ mkdir ~/.ssh [pg62、pg63、pg64]$ chmod 700 ~/.ssh [pg62、pg63、pg64]$ cd ~/.ssh [pg62、pg63、pg64]$ ssh-keygen -t rsa -f id_rsa_pgpool [pg62、pg63、pg64]$ ssh-copy-id -i id_rsa_pgpool.pub postgres@pg62 [pg62、pg63、pg64]$ ssh-copy-id -i id_rsa_pgpool.pub postgres@pg63 [pg62、pg63、pg64]$ ssh-copy-id -i id_rsa_pgpool.pub postgres@pg64 --验证 ssh postgres@serverX -i ~/.ssh/id_rsa_pgpool [root@pg62 .ssh]# su - postgres Last login: Wed Dec 10 16:41:47 CST 2025 from pg64 on pts/1 -bash-4.2$ ssh postgres@pg62 -i ~/.ssh/id_rsa_pgpool Last login: Wed Dec 10 16:42:15 2025 -bash-4.2$ hostname pg62 -bash-4.2$ exit logout Connection to pg62 closed. -bash-4.2$ ssh postgres@pg63 -i ~/.ssh/id_rsa_pgpool Last login: Wed Dec 10 16:41:56 2025 from pg64 -bash-4.2$ hostname pg63 -bash-4.2$ exit logout Connection to pg63 closed. -bash-4.2$ ssh postgres@pg64 -i ~/.ssh/id_rsa_pgpool Last login: Wed Dec 10 16:42:06 2025 from pg64 -bash-4.2$ hostname pg64 -bash-4.2$ exit logout Connection to pg64 closed.repl复制用户免密 为了允许 repl 用户在不指定密码的情况下进行流复制和在线恢复,并使用 postgres 执行 pg_rewind,我们在 postgres 用户的主目录中创建 .pgpass 文件,并将每个 PostgreSQL 服务器上的权限更改为 600。[pg62、pg63、pg64]$ vi /var/lib/pgsql/.pgpass pg62:5432:replication:repl:repl pg63:5432:replication:repl:repl pg64:5432:replication:repl:repl pg62:5432:postgres:postgres:postgres pg63:5432:postgres:postgres:postgres pg64:5432:postgres:postgres:postgres [pg62、pg63、pg64]$ chmod 600 /var/lib/pgsql/.pgpass四、部署pgpool-II# pg62、pg63、pg64服务器执行操作。安装依赖包libmemcached-1.0.16-5.el7.x86_64 基础包需要安装 mount /dev/cdrom /mnt yum install -y libmemcached排除pg仓库的pgpool包# 修改pgdg仓库文件 vi /etc/yum.repos.d/pgdg-redhat-all.repo [pgdg-common] ... exclude=pgpool* [pgdg15] ... exclude=pgpool* [pgdg14] ... exclude=pgpool* [pgdg13] ... exclude=pgpool* [pgdg12] ... exclude=pgpool* [pgdg11] ... exclude=pgpool* [pgdg10] ... exclude=pgpool* #拷贝修改的文件至其它服务器 scp /etc/yum.repos.d/pgdg-redhat-all.repo 192.168.1.63:/etc/yum.repos.d/pgdg-redhat-all.repo scp /etc/yum.repos.d/pgdg-redhat-all.repo 192.168.1.64:/etc/yum.repos.d/pgdg-redhat-all.repo安装pgpool-II[root@pg62 yum.repos.d]# yum install -y https://www.pgpool.net/yum/rpms/4.4/redhat/rhel-7-x86_64/pgpool-II-release-4.4-1.noarch.rpm Loaded plugins: langpacks, product-id, search-disabled-repos, subscription-manager This system is not registered with an entitlement server. You can use subscription-manager to register. pgpool-II-release-4.4-1.noarch.rpm | 5.7 kB 00:00:00 Examining /var/tmp/yum-root-IXf77b/pgpool-II-release-4.4-1.noarch.rpm: pgpool-II-release-4.4-1.noarch Marking /var/tmp/yum-root-IXf77b/pgpool-II-release-4.4-1.noarch.rpm to be installed Resolving Dependencies -- Running transaction check --- Package pgpool-II-release.noarch 0:4.4-1 will be installed -- Finished Dependency Resolution pgdg-common/7Server/x86_64/signature | 665 B 00:00:00 pgdg-common/7Server/x86_64/signature | 2.9 kB 00:00:00 !!! pgdg12/7Server/x86_64/signature | 665 B 00:00:00 pgdg12/7Server/x86_64/signature | 3.6 kB 00:00:00 !!! pgdg13/7Server/x86_64/signature | 665 B 00:00:00 pgdg13/7Server/x86_64/signature | 3.6 kB 00:00:00 !!! pgdg14/7Server/x86_64/signature | 665 B 00:00:00 pgdg14/7Server/x86_64/signature | 3.6 kB 00:00:00 !!! pgdg15/7Server/x86_64/signature | 665 B 00:00:00 pgdg15/7Server/x86_64/signature | 3.6 kB 00:00:00 !!! Dependencies Resolved ============================================
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

手机网站自适应屏幕宝应县建设工程管理局网站

深夜,一位有着8年经验的Java架构师,正看着屏幕上的Spring Boot代码陷入沉思。白天,他亲眼目睹了一个刚毕业两年、精通大模型的工程师,拿下了比他高出40%的年薪Offer。那一刻,他意识到,只懂Java的“金饭碗”…

张小明 2026/1/8 10:00:13 网站建设

普拓网站建设把wordpress改成返利网

个人简介慕婉学姐精通Java、PHP、微信小程序、Python、Golang和安卓开发等语言,擅长开发大数据、深度学习、网站、小程序、安卓应用和算法项目。平时从事项目定制开发、代码讲解、答辩教学和文档编写,也掌握一些降重技巧。感谢大家的持续关注&#xff01…

张小明 2026/1/7 11:36:50 网站建设

广西网站建设软件推广关键词seo优化服务

机器视觉,OpenCV,Qt,工业相机采集,图像采集,图像处理,卡尺工具,找线,找圆,颜色检测,模板匹配,形状匹配,海康工业相机采集基于形状的模…

张小明 2026/1/8 12:39:37 网站建设

北海住房和城乡建设部网站wordpress ajax接口

之所以会想写这个,首先是因为在知乎收到了这个推荐的问题,实际上不管是 AutoGLM 还是豆包 AI 手机,会在这个阶段被第三方厂商抵制并不奇怪,比如微信和淘宝一直以来都很抵制这种外部自动化操作,而非这次中兴的 AI 豆包手…

张小明 2026/1/8 12:39:34 网站建设

西宁专业网站建设广州抖音seo价格

引言:为什么前端类型转换特别“危险”?JavaScript作为一门动态弱类型语言,其灵活的类型系统既是它的魅力所在,也是许多诡异Bug的根源。与其他静态类型语言不同,JavaScript在运行时默默地执行着大量的隐式类型转换&…

张小明 2026/1/8 12:39:32 网站建设