话说初始化和设置完GUC参数后,改变了当前工作文件夹,给数据集文件夹加了文件锁postmaster.pid,接着就是初始化时区设置,这些都跳过去了,后来发现初始化时区用到了pg里的动态哈希表,决定还是把这个写出来。
动态哈希表在pg里使用的地方很多,pg使用它管理共享内存shared memory、锁、市区timezone等。Linux使用哈希表来管理内存、连接等。后面再讨论pg里的动态哈希表dynmaic hashtable。
1先上个图,看一下函数调用过程梗概,中间略过部分细节
初始化Timezones的方法调用过程图
这一节写图中红色方框圈起来的部分,上面的部分基本上在前面已经写过了,有小部分有略过。红色框中的部分就是初始化Timezones的过程调用,这主要做了两件事,一是创建了一个 ”Timezones”AllocSet/MemoryContext,二是建了一个pg中的动态哈希表,来管理/存放timezone。
2初始化全局时区global_timezones的过程
话说main()->…->PostmasterMain()->…-> pg_timezone_initialize()(以后用“->” 表示调用),先到前面的文章《pg启动过程中的那些事三》里提到的config_generic **类型的有序GUC参数数组guc_variables里用二分法查找config_string类型参数timezone,此时该参数还没有设置,接着->select_default_timezone()->identify_system_timezone()函数根据OS环境变量识别操作系统的timezone设置,再
->select_default_timezone()->set_global_timezone()->pg_tzset()在内存里初始化一个静态全局变量动态哈希表static HTAB * timezone_cache,在哈希表timezone_cache里记录时区结构pg_tz_cache类型的实例。然后使pg_tz *类型全局指针变量 global_timezone指向哈希表中的pg_tz_cache结构类型实例中pg_tz结构的成员tz。最后->SetConfigOption()设置GUC参数“timezone”为“ASIA/Hong_Kong”(这个是我PC上跑的结果)。
下面是pg_tz_cache、pg_tz等机构定义。
typedef struct
{
/* tznameupper contains the all-upper-case name of thetimezone */
char tznameupper[TZ_STRLEN_MAX+ 1];
pg_tz tz;
} pg_tz_cache;
struct pg_tz
{
/* TZname contains the canonically-cased name of thetimezone */
char TZname[TZ_STRLEN_MAX+ 1];
struct state state;
};
struct state
{
int leapcnt;
int timecnt;
int typecnt;
int charcnt;
pg_time_t ats[TZ_MAX_TIMES];
unsigned chartypes[TZ_MAX_TIMES];
struct ttinfo ttis[TZ_MAX_TYPES];
char chars[BIGGEST(BIGGEST(TZ_MAX_CHARS+ 1, 3 /* sizeof gmt */ ),
(2 * (TZ_STRLEN_MAX + 1)))];
struct lsinfo lsis[TZ_MAX_LEAPS];
};
struct ttinfo
{ /* time type information */
long tt_gmtoff; /* UTC offset inseconds */
int tt_isdst; /* used to settm_isdst */
int tt_abbrind; /* abbreviationlist index */
int tt_ttisstd; /* TRUE iftransition is std time */
int tt_ttisgmt; /* TRUE iftransition is UTC */
};
struct lsinfo
{ /* leap second information */
pg_time_t ls_trans; /* transition time */
long ls_corr; /* correctionto apply */
};
pg_tz_cache的结构在内存里看起来是这样的。
时区相关结构图
初始化global_timezone是从->select_default_timezone()->set_global_timezone() ->pg_tzset()->init_timezone_hashtable()->hash_create()开始的(调用过程要是看晕了就看上面的调用过程图吧),先初始化一个AllocSet/MemoryContext类型变量“Timezones”,接着在AllocSet/MemoryContext类型的“Timezones”实例里就是HTAB、HASHHDR、HashSegment、HashBucket、HashElemen等等一堆招呼,初始化成了“Timezones”动态哈希表。熟悉哈希表/哈希算法的同学看着HashBucket、HashElement也能猜出来大概是干什么用的,HashSegment是干什么的?这个和动态哈希表“dynmaic
hashtable”的动态,或者说可扩展哈希表的可扩展有关。我认为用“可扩展哈希表”更能体现“dynmaic hashtable”的功能,更贴近中国人用词习惯,以后就用“可扩展哈希表”吧。可扩展哈希表以后再讨论。pg里还有个Shared memory index,也是这个可扩展哈希表类型的,是和共享内存管理有关的东东,到内存管理机制时再讨论。
经过一连串的调用,hash_create创建的可扩展哈希表“Timezones”是一个由256个HashSegment,256个HashBucket,4个HashSegment+Entry组成的哈希表。在pg里,有的哈希表是放在内存上下文MemoryContext中的,有的哈希表是放在共享内存shared memory里的,这个 “Timezones”哈希表是放在“Timezones”内存上下文里的。为了看起来更清晰,就没有把“Timezones”哈希表放到AllocBlock里的AllocChunk里。结构图在下面。
“Timezones”哈希表结构
pg里的timezone文件以PG_BINARY格式存放在%PostgreSQL Home%\share\timezone里。
分享到:
相关推荐
一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: . 50 PostgreSQL PostgreSQL...
nacos-2.0.1 postgresql初始化脚本
PostgreSQL的学习心得和知识总结(四十五)|关于PostgreSQL数据库开源作业调度扩展 pg_cron 默认GMT时区修改 的实现方案
Docker映像具有:当前组件版本: PostgreSQL: 12.5 () PostGIS: 3.1.1 () TimescaleDB: 2.0.1 () 如何建造: $ docker build -t binakot/postgresql-postgis-timescaledb . 如何运行: $ docker run -d --...
postgresql PGCA 课程PPT01_postgresql_PGCA_PGCP_PGCM_课程全免费 postgresql PGCA 课程PPT01_postgresql_PGCA_PGCP_PGCM_课程全免费 postgresql PGCA 课程PPT01_postgresql_PGCA_PGCP_PGCM_课程全免费 postgresql ...
创建 PostgreSQL 实例后,您还需要进行 PostgreSQL 实例的初始化,以轻松启用实例。操作步骤登录 PostgreSQL 控制台,在实例列表,选
此 FDW 允许您从 PostgreSQL 服务器中的 ClickHouse 数据库中进行 SELECT 和 INSERT。 FDW 支持聚合下推和连接下推等高级功能。 这些通过将远程服务器的资源用于这些资源密集型操作来显着提高性能。文档支持的 ...
Maven坐标:org.postgresql:postgresql:42.3.1; 标签:postgresql、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构...
:face_with_monocle: :elephant: anyarray_...安装使用以下命令修补和编译PostgreSQL : $ git clone git://git.postgresql.org/git/postgresql.git$ cd postgresql$ patch -p1 < ~/Downloads/anyarray_anyelemen
enix.postgresql 使用在UNIX主机上部署和配置上游发行版的。... postgresql__global_config_options设置到postgresql.conf中的全局配置选项。 常见的选择是: postgresql__global_config_options: -
Maven坐标:org.postgresql:postgresql:42.2.5; 标签:postgresql、中英对照文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和...
PostgreSQL Ansible角色 Ansible角色,用于安装和配置PostgreSQL集群,数据库和用户。 请参阅。安装此角色已在Ansible 2.5.0及更高版本上进行了测试。 安装: ansible-galaxy install trainline-eu.ansible_...
在ormconfig.ts文件中设置数据库设置 设置.env TYPEORM_HOST= TYPEORM_USERNAME= TYPEORM_PASSWORD= TYPEORM_DATABASE= DEBUG=true ACCESS_TOKEN_SECRET= REFRESH_TOKEN_SECRET= SESSION_SECRET= FRONTEND_URL=...
hstore-js Postgresql hstore 字符串化和解析函数,支持嵌套的 hstore 语法。安装$ npm install hstore.js用法选项 { // key: default value array_square_brackets : false , boolean_as_integer : false , numeric...
存储过程 postgresql postgresql存储过程
mysql |本角色在语法上引用了主变量,程序运行时需要确保已经运行: mariadb | PostgreSQL | mongodb等角色。以mysql为例: roles: - {role: role_common, tags: "role_common"} - {role: role_cloud, tags: ...
最新版本PostgreSQL JDBC驱动包,还包括老版本驱动包: postgresql-8.4-703.jdbc4(支持PostgreSQL 8) postgresql-9.4.1212(支持PostgreSQL 9) postgresql-42.2.10(支持PostgreSQL 42)
POSTgreSQL:51风控系统背后的利器_
从零初始化一个SpringBoot项目,集成PostgreSQL并使用JPA和MyBatis两种方式对其进行操作。这里只记录PostgreSQL相关操作,项目创建过程不详细介绍,类似流程可参考文章<<Spring Boot:Idea从零开始初始化后台项目>>...
本套程序是在VS2005下C#开发,...在对PostgreSQL数据库进行操作时,用到了如何调用存储过程来完成各项操作。 将App_Data下的数据库文件导入到PostgreSQL 8.3版里面,库名为:HYGL 然后修改web.config中的配置即可使用