【应用】PostgreSQL 流复制配置

news2025/1/10 3:18:15

PostgreSQL 流复制配置

  • centos7 安装 postgresql
    • 时序库 timescaleDB 的安装
  • postgresql-14 主从流复制
    • 主库配置
    • 从库配置
    • 同步流复制与异步流复制
      • 异步流复制转换为同步流复制
    • 流复制的相关参数
  • 主从流复制原理
    • PostgreSQL WAL 日志
    • 主从流复制架构
    • 主从流复制的过程
  • 基于 docker swarm 的主从流复制配置
    • 配置前准备
    • 主库配置
    • 从库配置
    • 测试同步状态
    • 异步流复制转换为同步流复制

centos7 安装 postgresql

下载安装 postgresql-14

# Install the repository RPM:
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm

# Install PostgreSQL:
sudo yum install -y postgresql14-server

# Optionally initialize the database and enable automatic start:
sudo /usr/pgsql-14/bin/postgresql-14-setup initdb

修改配置文件

"/var/lib/pgsql/14/data/postgresql.conf"

listen_addresses = '*'        # what IP address(es) to listen on;
                    # comma-separated list of addresses;
                    # defaults to 'localhost'; use '*' for all
                    # (change requires restart)
port = 5432                # (change requires restart)

"/var/lib/pgsql/14/data/pg_hba.conf"

# IPv4 local connections:
host    all             all             127.0.0.1/32            scram-sha-256
host    all             all             0.0.0.0/0               md5

启动 postgresql-14 服务

启动命令:systemctl start postgresql-14
重启命令:systemctl restart postgresql-14
停止命令:systemctl stop postgresql-14

切换到安装自动创建的 postgres 用户,修改密码(默认无密码)

[root@localhost ~]# su - postgres
-bash-4.2$ psql
psql (14.5)
输入 "help" 来获取帮助信息.

postgres=# ALTER USER postgres ENCRYPTED PASSWORD '961231zqf';
ALTER ROLE
postgres=# exit
-bash-4.2$ exit
登出

使用连接工具 navicat 进行测试,注意关闭防火墙

systemctl stop firewalld.service
systemctl disable firewalld.service

时序库 timescaleDB 的安装

执行安装,centOS 中没有对应的安装包,需进行配置

在 root 用户下输入下列命令并执行

yum install https://download.postgresql.org/pub/repos/yum/reporpms/EL-$(rpm -E %{centos})-x86_64/pgdg-redhat-repo-latest.noarch.rpm

配置 timescaledb 仓库

tee /etc/yum.repos.d/timescale_timescaledb.repo <<EOL
[timescale_timescaledb]
name=timescale_timescaledb
baseurl=https://packagecloud.io/timescale/timescaledb/el/$(rpm -E %{rhel})/\$basearch
repo_gpgcheck=1
gpgcheck=0
enabled=1
gpgkey=https://packagecloud.io/timescale/timescaledb/gpgkey
sslverify=1
sslcacert=/etc/pki/tls/certs/ca-bundle.crt
metadata_expire=300
EOL

更新本地仓库列表

yum update

执行安装

yum install timescaledb-2-postgresql-14

修改配置文件/var/lib/pgsql/14/data/postgresql.conf,配置时序库

shared_preload_libraries = 'timescaledb'    # (change requires restart)

创建目录,并将修改后的配置文件复制到该目录下

mkdir -p /etc/postgresql/14/main/
cp /var/lib/pgsql/14/data/postgresql.conf /etc/postgresql/14/main/

使用 navicat 连接数据库,首先创建新的数据库 timescaledb

CREATE DATABASE timescaledb;

连接到新创建的数据库,进行扩展

CREATE EXTENSION IF NOT EXISTS timescaledb;

postgresql-14 主从流复制

主库从库
192.168.86.133192.168.86.131

主库配置

修改配置文件:"/var/lib/pgsql/14/data/postgresql.conf",主要关注wal_level属性

wal_level = replica            # minimal, replica, or logical
                               # (change requires restart)

在主库中创建一个用于复制的账号,用户名密码均为 repl

[root@localhost ~]# su - postgres
上一次登录:四 113 17:11:18 CST 2022pts/1 上
-bash-4.2$ psql
psql (14.5)
输入 "help" 来获取帮助信息.

postgres=# create role repl login replication encrypted password 'repl';
CREATE ROLE
postgres=# exit
-bash-4.2$ exit
登出

修改配置文件:"/var/lib/pgsql/14/data/pg_hba.conf",添加下列配置

host    replication     repl      192.168.86.131/32       md5

重启主库服务

systemctl restart postgresql-14

至此主库配置完毕

从库配置

首先停止从库服务

systemctl stop postgresql-14

删除数据库主目录 data

[root@localhost ~]# cd /var/lib/pgsql/14
[root@localhost 14]# rm -rf data

使用pg_basebackup命令同步数据库

[root@localhost 14]# pg_basebackup -h 192.168.86.133 -p 5432 -U repl -R -F p -P -D data

参数说明:
选项    说明
-p    主库数据库端口
-U    流复制用户
-W    使用密码验证,要用replica的密码
-Fp   备份输出正常的数据库目录
-Xs   使用流复制的方式进行复制
-Pv   输出复制过程的详细信息
-R    为备库创建recovery.conf文件。但是pgsql 10以后的新版本的pgsql不需要这个文件了。
-D    指定创建的备库的数据库目录

重新启动从库数据库服务

systemctl restart postgresql-14

若存在启动失败问题,则可能是权限问题导致

[root@localhost 14]# systemctl restart postgresql-14
Job for postgresql-14.service failed because the control process exited with error code. See "systemctl status postgresql-14.service" and "journalctl -xe" for details.
[root@localhost 14]# systemctl status postgresql-14
● postgresql-14.service - PostgreSQL 14 database server
   Loaded: loaded (/usr/lib/systemd/system/postgresql-14.service; disabled; vendor preset: disabled)
   Active: failed (Result: exit-code) since 五 2022-11-04 08:37:21 CST; 35s ago
     Docs: https://www.postgresql.org/docs/14/static/
  Process: 1392 ExecStartPre=/usr/pgsql-14/bin/postgresql-14-check-db-dir ${PGDATA} (code=exited, status=1/FAILURE)

11月 04 08:37:21 localhost.localdomain systemd[1]: Starting PostgreSQL 14 database server...
11月 04 08:37:21 localhost.localdomain systemd[1]: postgresql-14.service: control process exited, code=exited status=1
11月 04 08:37:21 localhost.localdomain systemd[1]: Failed to start PostgreSQL 14 database server.
11月 04 08:37:21 localhost.localdomain systemd[1]: Unit postgresql-14.service entered failed state.
11月 04 08:37:21 localhost.localdomain systemd[1]: postgresql-14.service failed.

重新为 postgres 用户授权,启动服务成功

[root@localhost 14]# chown -R  postgres:postgres /var/lib/pgsql/14/data
[root@localhost 14]# systemctl start postgresql-14

至此简单的主从流复制配置完成,可连接数据库进行操作进行检验,从库为只读库,可以在主库执行下列命令查询从库相关信息

select pid,state,client_addr,sync_priority,sync_state,sent_lsn,write_lsn from pg_stat_replication;

同步流复制与异步流复制

流复制分为同步流复制和异步流复制:

  • 同步流复制:可以在主库故障时确保数据的一致,但是当网络或者备库出现问题时,会导致主库的事务 hang 住;

  • 异步流复制:不会影响主库的性能,但是在主库故障时,可能会丢掉小部分数据;

异步流复制转换为同步流复制

上述的流复制配置过程为异步流复制的配置过程,可以通过指令查看当前的数据库状态

使用 postgres 用户登录数据库,执行查询,可以看到sync_state对应的值为async

select * from pg_stat_replication;

修改主库配置文件/var/lib/pgsql/14/data/postgresql.conf,配置ynchronous_standby_names属性

synchronous_standby_names = 'slave'

重新启动主数据库

cd /usr/pgsql-14/bin/
./pg_ctl restart

使用 postgres 用户登录备用数据库,查询备库状态,保存conninfo字段的信息

select * from pg_stat_wal_receiver;

修改备库的系统设置,新值为上一步保存的conninfo字段信息加上application_name=slave

alter system set primary_conninfo = 'application_name=slave user=repl password=repl channel_binding=disable host=192.168.86.133 port=5432 sslmode=disable sslcompression=0 ssl_min_protocol_version=TLSv1.2 gssencmode=disable krbsrvname=postgres target_session_attrs=any';

重新启动从数据库

cd /usr/pgsql-14/bin/
./pg_ctl restart

重新查看主库状态

postgres=# select * from pg_stat_replication ;
 pid  | usesysid | usename | application_name |  client_addr   | client_hostname | client_port |         backend_start         | backend_xmin |   state   |  sent_lsn  | write_lsn
| flush_lsn  | replay_lsn |    write_lag    |    flush_lag    |   replay_lag    | sync_priority | sync_state |          reply_time
------+----------+---------+------------------+----------------+-----------------+-------------+-------------------------------+--------------+-----------+------------+------------
+------------+------------+-----------------+-----------------+-----------------+---------------+------------+-------------------------------
 1915 |    24577 | repl    | slave            | 192.168.86.131 |                 |       47664 | 2022-11-09 09:52:11.088431+08 |              | streaming | 0/DD99DFA8 | 0/DD99DFA8
| 0/DD99DFA8 | 0/DD99DFA8 | 00:00:00.001495 | 00:00:00.002756 | 00:00:00.003071 |             1 | sync       | 2022-11-09 09:52:11.469006+08
(1 行记录)

重新查看备库状态

postgres=# select * from pg_stat_wal_receiver ;
 pid  |  status   | receive_start_lsn | receive_start_tli | written_lsn | flushed_lsn | received_tli |      last_msg_send_time       |     last_msg_receipt_time     | latest_end_ls
n |       latest_end_time       | slot_name |  sender_host   | sender_port |
                                           conninfo

------+-----------+-------------------+-------------------+-------------+-------------+--------------+-------------------------------+-------------------------------+--------------
--+-----------------------------+-----------+----------------+-------------+--------------------------------------------------------------------------------------------------------
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
------------------
 1626 | streaming | 0/DD000000        |                 1 | 0/DD99DFA8  | 0/DD99DFA8  |            1 | 2022-11-09 09:52:41.495931+08 | 2022-11-09 09:52:41.491104+08 | 0/DD99DFA8
  | 2022-11-09 09:52:11.4719+08 |           | 192.168.86.133 |        5432 | user=repl password=******** channel_binding=disable dbname=replication host=192.168.86.133 port=5432 ap
plication_name=slave fallback_application_name=walreceiver sslmode=disable sslcompression=0 sslsni=1 ssl_min_protocol_version=TLSv1.2 gssencmode=disable krbsrvname=postgres target_
session_attrs=any
(1 行记录)

至此异步流复制切换同步流复制完成,可以使用客户端连接进行验证测试。

流复制的相关参数

  • 日志级别wal_level:该参数决定了有多少信息写入 WAL 日志

    • 默认值replica,该模式支持流复制与归档,同时支持备库的只读查询;

    • minimal:对实例 crash 恢复所需要的进行记录,其余不记录日志,该模式记录的日志信息不足以支撑 WAL 的流复制与归档;

    • logic:在 replica 的基础上增加一些信息以支持逻辑解码,该模式会增大 WAL 日志,尤其是大量 update、delete 的库;

  • 同步模式synchronous_commit:该参数决定数据同步的模式

    • off:对于本机的 WAL 日志不需要写入到磁盘就可以提交,是一种异步模式,存在数据丢失的风险;

    • local:不管有没有从库,只需要保证本机的 WAL 日志写入到磁盘就可以提交;

    • remote_write:等待主库的日志写入到磁盘,同时日志传送到从库的缓存当中才能提交,生产环境下一般选择该模式;

    • on:若不存在从库,则需要本机 WAL 写入磁盘后才能提交;若存在同步从库,则需要等待远程从库的 WAL 也写入到磁盘后才能提交;

    • remote_apply:PG 高版本的功能,需要从库将更改写入磁盘并回放日志成功,用于负载均衡、读写分离等;

  • 从机复制列表synchronous_standby_names:该参数用于在主机上配置从机的复制列表

    • synchronous_standby_names=‘s1’代表 s1 备机返回就可以提交(s1 为备机名);

    • synchronous_standby_names=’*’代表匹配任意主机,也就是任意主机返回就可以提交;

  • max_wal_senders:指定 WAL 日志发送进程的最大并发连接数,设置为 0 表示禁用 replication;

  • checkpoint_timeout:自动 WAL 检查点之间的最长时间,合理值为 30s 到 1day 之间,默认值 5min。增加这个参数的值会增加崩溃恢复所需的时间。

  • checkpoint_completion_target:指定检查点完成的目标,该值在 0 - 1 之间。假如我的 checkpoint_timeout 设置是 30min,而 WAL 日志生成了10G,那么设置成 0.5 就允许在 15min 内完成 checkpoint,调大这个值就可以降低c heckpoint 对性能的影响,但是万一数据库出现故障,那么这个值设置越大数据就越危险。

  • max_wal_size:在自动检查点之间允许 WAL 日志的最大容量,默认为 1 GB,增加这个参数的值会增加崩溃恢复所需的时间。

主从流复制原理

在 PostgreSQL 9.1 版本之前,主从复制以 WAL 日志为基本单位,主库写完一个 WAL 日志后才传送到备库,这导致主备数据库之间的延迟很大。

PostgreSQL 9.1 引入了主备流复制,传输的单位时 WAL 日志的 record,备库不断从主库同步相应的数据。

PostgreSQL WAL 日志

PostgreSQL 的流复制实际上就是通过 WAL 日志进行数据同步的过程。WAL 全称 Write Ahead Log,即预写式日志。

WAL 日志十分重要,其核心思想就是:先写入日志文件,再写入数据。

当数据库中的数据发生变更时,主要存在下列几个重要的节点:

  • change 发生时:数据库首先将变更的内容计入 wal buffer,再将变更后的数据写入 data buffer;

  • commit 发生时:数据库将 wal buffer 中的数据刷新到磁盘;

  • checkpoint 发生时:数据库将所有的 data buffer 刷新到磁盘;

主从流复制架构

PostgreSQL 主从流复制的核心主要包括三个进程:

  • walsender:用于主库发送 WAL 日志到从库;

  • walreceiver:用于从库接收主库的 WAL 日志;

  • startup:用于从库 apply 日志;
    在这里插入图片描述

主从流复制的过程

  1. 主从数据库启动后,备库启动 walreceiver 进程,向主库发送请求连接;

  2. 主库接收到请求后,启动 walsender 进程,与 walreceiver 建立 TCP 连接;

  3. 从库发送最新的 WAL LSN 给主库(LSN 可以理解为日志的偏移量);

  4. 主库进行 LSN 对比,同时定期向从库发送心跳信息来确认备库的可用性,并将没有传递的 WAL 日志发送;

  5. 从库调用函数将 WAL 写入缓存,然后将 WAL 刷新到磁盘;

基于 docker swarm 的主从流复制配置

docker swarm 集群的搭建过程参照:docker swarm 集群搭建

配置前准备

编写 docker compose 模板文件,对服务进行配置。本配置启动一主一从两个数据库,直接使用时序库官方提供的 timescaledb 镜像

version: "3"
services:
# postgres-1 服务
  postgres-1:
    image: timescale/timescaledb:latest-pg14
    networks:
      - my-multi-host-network
    environment:
      - POSTGRES_DB=postgres
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=961231zqf
    volumes:
      - /root/postgresql/data:/var/lib/postgresql/data
    ports:
      - 5432:5432
    deploy:
      placement:
        constraints:
          - node.hostname == node01


# postgres-2 服务
  postgres-2:
    image: timescale/timescaledb:latest-pg14
    networks:
      - my-multi-host-network
    environment:
      - POSTGRES_DB=postgres
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=961231zqf
    volumes:
      - /root/postgresql/data:/var/lib/postgresql/data
    ports:
      - 5433:5432
    deploy:
      placement:
        constraints:
          - node.hostname == node02

# 网络配置
networks:
  my-multi-host-network:
    driver: overlay

分别在 node 1 节点与 node 2 节点新建映射卷文件夹,映射路径需要与配置文件中路径相对应,同时在两个节点新建名为 postgres 的用户

mkdir -p /root/postgres/data
useradd postgres

在主节点 master 按照上述 compose 文件启动服务

docker stack deploy -c docker_postgres.yml postgres

使用下列命令可以查看服务的运行情况

docker service ls

主库配置

在主数据库节点 node 1 进行配置,使用下列指令查询当前节点正在运行的容器

docker ps

以 postgres 用户进入 timescale/timescaledb:latest-pg14 容器,其中e052dfa54dbf为容器的 CONTAINER ID

docker exec -it -u postgres e052dfa54dbf /bin/bash

进入/var/lib/postgresql/data/,修改配置文件postgresql.conf

cd /var/lib/postgresql/data/
vi postgresql.conf

主要修改wal_level属性,取消对应行前面的注释

wal_level = replica                     # minimal, replica, or logical
                                        # (change requires restart)

进入/var/lib/postgresql/data/,修改配置文件pg_hba.conf

cd /var/lib/postgresql/data/
vi postgresql.conf

在文件末尾添加如下配置

host    replication     repl      0.0.0.0/0       md5

登录数据库,创建用于复制的账号,用户名与密码均为 repl

bash-5.1$ psql
psql (14.1)
Type "help" for help.

postgres=# create role repl login replication encrypted password 'repl';
CREATE ROLE
postgres=# exit

在容器内重新启动主数据库

pg_ctl restart

重新查看 node 1 的服务,查看数据库是否启动成功,若启动成功则主库配置完毕

从库配置

在从数据库节点 node 2 进行配置,使用下列指令查询当前节点正在运行的容器

docker ps

以 postgres 用户进入容器

docker exec -it -u postgres d853cdb73a76 /bin/bash

进入/var//lib/postgresql/,清空 data 文件夹中的所有数据

cd /var/lib/postgresql/
rm -rf data/*

利用pg_basebackup指令从主数据库将数据复制到从库,使用 repl 账号,密码为 repl

pg_basebackup -h 192.168.86.131 -p 5432 -U repl -R -F p -P -D data

执行完成后,等待容器自动重启,重启时将会退出容器。退出容器后查看 node 2 节点运行的容器状态,此时容器 ID 将会变换,若容器正常运行则主从异步流复制配置完毕

测试同步状态

使用 navicat 连接两个数据库,在主库中使用下列语句查询主从配置信息

select * from pg_stat_replication;

在主库中执行相应的增删改语句,查看从库的复制情况,从库为只读库

CREATE TABLE test(id INT);

DROP TABLE test;

异步流复制转换为同步流复制

在主库节点 node 1 查询当前数据库的主从复制状态,此时sync_state字段值为async

select usename, application_name, client_addr, state, sync_state from pg_stat_replication;

使用 postgres 用户进入主库节点 node 1 的 pg 库容器内部进行配置

docker ps
docker exec -it -u postgres 01e4813649de /bin/bash

修改配置文件postgresql.conf

cd /var/lib/postgresql/data/
vi postgresql.conf

配置属性synchronous_standby_names

synchronous_standby_names = 'slave'     # standby servers that provide sync rep
                                # method to choose sync standbys, number of sync standbys,
                                # and comma-separated list of application_name
                                # from standby(s); '*' = all

配置完成后重新启动主数据库并查看容器运行情况,主库配置完成

使用 navicat 等工具连接从库,使用下列语句查询复制信息

select * from pg_stat_wal_receiver;

记录查询结果中connifo字段值,并在原始值字段前添加application_name=slave,然后执行系统变量的更新(application_name属性的值为之前设置的synchronous_standby_names属性值)

alter system set primary_conninfo = 'application_name=slave user=repl password=repl channel_binding=prefer dbname=replication host=192.168.86.131 port=5432 fallback_application_name=walreceiver sslmode=prefer sslcompression=0 sslsni=1 ssl_min_protocol_version=TLSv1.2 gssencmode=prefer krbsrvname=postgres target_session_attrs=any';

使用 postgres 用户进入从库容器内部,重新启动数据库

docker ps
docker exec -it -u postgres b4bff118dae5 /bin/bash
pg_ctl restart

重新查询从库节点 node 2 容器运行状态,若正常运行则从库配置完毕

在主库中重新查询数据库复制信息,此时sync_state字段值变为sync,配置成功

select usename, application_name, client_addr, state, sync_state from pg_stat_replication;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/21676.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CMSC5713-IT项目管理之七、质量管理Quality Management

文章目录7.1 Quality7.2. Software Quality7.2.1. ISO/IEC 25010 Software Qualities7.2.2. Internal versus External qualities7.2.3. Software Metrics7.3. Quality Specification7.4. Project Quality Management7.4.1. Quality Planning7.4.2. Quality Assurance7.4.2.1. …

vscode 阅读 linux kernel 源码

前言 虽然身边的朋友大都在使用 source insight&#xff0c;但我却更喜欢 vscode。 不过 vscode 在代码搜索上确实不如 source insight&#xff0c;这点上我也是吃过亏的。阅读大型代码时&#xff0c;常常搜索不到关键代码&#xff0c;导致对代码的理解不充分。 当使用 vscode…

Java-反射

前言 动态语言与静态语言 动态语言 是一类在运行时可以改变其结构的语言&#xff1a;例如新的函数、对象、甚至代码可以被引进&#xff0c;已有的函数可以被删除或是其他结构上的变化。通俗点说就是在运行时代码可以根据某些条件改变自身结构主要动态语言有&#xff1a;Object…

【开源电路】STM32F401RCT6开发板

【开源电路】STM32F401RCT6开发板&#x1f337;实物PCBA&#xff1a; &#x1f33c;优化后的3D效果图 &#x1f4da;STM32F401RCT6开发板简介 &#x1f4d1;主控是LQFP-64封装的STM32F401RCT6芯片&#xff0c;Micro USB接口供电&#xff0c;功能引脚全部引出&#xff0c;一个…

金融强化学习与finRL开发包

原创文章第110篇&#xff0c;专注“个人成长与财富自由、世界运作的逻辑&#xff0c; AI量化投资”。 01 一些感受 时代的一粒沙&#xff0c;落在每个人身上就是一座山。 这三年&#xff0c;对于这句话&#xff0c;相信很多人更能感同身受。 看历史风云变幻&#xff0c;轻轻…

力扣(LeetCode)21. 合并两个有序链表(C++)

迭代 同时遍历两个链表 &#xff0c; 当前结点值较小的结点插入新的链表尾部。直到有一个链表为空 &#xff0c; 我们将另一个非空链表插入新的链表尾部。 提示 : 使用哑结点&#xff0c;避免特判头结点。二路归并思想应用于链表~ class Solution { public:ListNode* mergeT…

gRPC gateway - Http Restful API gRPC 协议转换

gRPC gateway - http restful gRPC gateway 介绍 gRPC-Gateway 是protocalBufffer的编译插件,根据protobuf的服务定义自动生成反向代理服务器&#xff0c;并将Restful Http API 转化为 gRPC通信协议。反向代理服务器根据 google.api.http 注解生成。 gRPC底层是使用HTTP2 协…

mybatis # $

总结&#xff1a; # 你传入的变量类型会被保留 $ 本质就是拼接 不会考虑拼串的 $ 情况下 参数是整数 跟参数是字符串 字符串情况&#xff1a; 缺少’’ 相当于字符串拼接 ”select * from t_user where username “ “张三” ”select * from t_user where username 张三&…

java 容器

java 容器 数组 数组的扩容问题 ArrayList 的默认初始化容量为0&#xff0c;首次添加元素时&#xff0c;创建容量为&#xff08;10 || 添加集合大小) ,以后每次扩容的话&#xff0c;为当前容量的1.5倍 public ArrayList() {/*初始化容量大小为0private static final Object…

CEAC之《计算机应用助理工程师》2

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;微微的猪食小窝 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 微微的猪食小窝 原创 收录于专栏 【CEAC证书】 1组合框的常用属性有 ____________ 。 A、Index B、Text C、Caption D、ListCountA,B,D2在…

ES6 入门教程 16 Reflect 16.2 静态方法 16.3 实例:使用 Proxy 实现观察者模式

ES6 入门教程 ECMAScript 6 入门 作者&#xff1a;阮一峰 本文仅用于学习记录&#xff0c;不存在任何商业用途&#xff0c;如侵删 文章目录ES6 入门教程16 Reflect16.2 静态方法16.2.1 Reflect.get(target, name, receiver)16.2.2 Reflect.set(target, name, value, receiver)1…

数据结构之:数组

数组初体验之数组中重复的数字 数组 &#xff1a; 有限个 相同类型的变量 组成的有序集合 int[] arr; int arr[]; // 静态初始化 String[] strArr {"和平精英","王者荣耀","开心消消乐","欢乐斗地主"}; // 动态初始化 String[] strAr…

自学 TypeScript 第三天 使用webpack打包 TS 代码

安装&#xff1a; 首先第一步&#xff0c;我们要初始化我们项目&#xff0c;在目录下输入 npm init 接下来&#xff0c;我们的安装几个工具 npm i -D webpack webpack-cli typescript ts-loader -D 意思是 开发依赖&#xff0c;也就是我们现在所安装的依赖都是开发依赖&am…

知乎 日报

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言评论界面首页cell的小标题的文字显示下拉刷新前言 这周完成了评论内容&#xff0c;改了一些小bug。收藏界面正在加油&#xff0c;FMDB库目前不是很理解 评论界面…

【C++初阶】三、类和对象(中)

在上一篇类和对象中&#xff0c;我们初步了解了类和对象的基本概念&#xff0c;知道了什么是类&#xff0c;接下来一起看看类和对象的具体细节和实现吧。&#xff08;以日期类举例&#xff09; 文章目录类和对象【中】1.类的6个默认成员函数2. 构造函数2.1 构造函数定义2.2 构造…

SpringBoot SpringBoot 开发实用篇 4 数据层解决方案 4.16 SpringBoot 整合 ES 客户端操作

SpringBoot 【黑马程序员SpringBoot2全套视频教程&#xff0c;springboot零基础到项目实战&#xff08;spring boot2完整版&#xff09;】 SpringBoot 开发实用篇 文章目录SpringBootSpringBoot 开发实用篇4 数据层解决方案4.16 SpringBoot 整合 ES 客户端操作4.16.1 环境准备…

[附源码]java毕业设计停车场收费管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

DP入门(一)

前言&#xff1a;由于作者经常卡力扣周赛最后一题的dp&#xff0c;因此决定痛改前非&#xff0c;从头做人&#xff0c;争取下次能做出最后一道dp ak周赛&#xff01;呜呜呜加油~~ 因此 这个系列的文章不会教 dp &#xff0c;只会讲刷题思路&#xff0c;目前的计划是先更 lc 的题…

[Spring Cloud] RestTemplate跨进程调用

✨✨个人主页:沫洺的主页 &#x1f4da;&#x1f4da;系列专栏: &#x1f4d6; JavaWeb专栏&#x1f4d6; JavaSE专栏 &#x1f4d6; Java基础专栏&#x1f4d6;vue3专栏 &#x1f4d6;MyBatis专栏&#x1f4d6;Spring专栏&#x1f4d6;SpringMVC专栏&#x1f4d6;SpringBoot专…

【k8s】5、资源管理命令-声明式

文章目录一、 yaml和json介绍1、yuml语言介绍2、k8s支持的文件格式3、yaml和json的主要区别二、声明式对象管理1、命令式对象配置2、声明式对象配置3、声明式对象管理命令介绍三、编写资源配置清单1、 编写yaml文件2、 启动并查看资源3、创建service服务对外提供访问测试4、创建…