以前学习postgresql的笔记

create table 消耗 OID

  • 如create table my_test_table, 他本身会消耗一个

  • 会在pg_type中插入两条记录_my_test_table和my_test_table会消耗掉两个oid

  • 如果该表需要toast会生成一个改变的toast表和toast index表消耗另外两个,查看过程如下:

  • create table my_test_table(a int, b char(8192));

  • select oid, relname from pg_class where relname='my_test_table';

  • -- oid = 16384

  • select oid, relname from pg_class where relname like '%16384%';

  • select typname, oid from pg_type where typname like '%my_test_table';

OID同步过程

OID同步原因:当创建表、视图、函数等对象时,对象需要分配新的OID。创建对象的OID全

局唯一,因此要在所有的coordinator和datanode上获取一个最大的OID。以create table为例,

具体流程如下:

1)首先和所有的dn及除自己以外的co建立连接。

2)向所有建立连接的节点发送获取OID请求,收到请求的节点,把本节点最大的OID发给coordinator。

3)coordinator节点收到其他几点发来的oid,选一个最大的oid,然后调用SetNextAssignObjectId

函数,使当前co节点下一个要分配的OID为集群中最大的OID。

4)然后才执行create语句,结构体CreateStmt中成员TableOidInfo用来存储获取的最大的

OID,当前coordiator把查询计划下发到其它节点,其它节点获取到最大OID后调用函数

heap_create_with_catalog,在自己节点上创建表

OID同步涉及到的系统表

pg_class

pg_namespace --create schema

pg_constraint

pg_operator

pg_ts_parser

pg_ts_dict

pg_ts_template

pg_ts_config

pg_collation

pg_am

pg_extension

pg_foreign_data_wrapper

pg_foreign_server

pg_user_mapping

pg_type

pg_enum

pg_proc

pg_rewrite

pg_trigger

pg_language

pg_conversion

pg_cast

pg_opfamily

pg_opclass

pg_tablespace

OID同步去除

当前实现可能存在问题是,当有节点或所有节点的OID回绕了,创建对象非常有可能失败。OID同步去除参考

PG-XL的做法,在查询计划中发送对象名,到节点上再转成本地OID。

笔记 postgresql oid同步的更多相关文章

  1. 运维笔记--postgresql占用CPU问题定位

    运维笔记--postgresql占用CPU问题定位 场景描述: 业务系统访问变慢,登陆服务器查看系统负载并不高,然后查看占用CPU较高的进程,发现是连接数据库的几个进程占用系统资源较多. 处理方式: ...

  2. Linux内核设计笔记10——内核同步

    Linux内核同步笔记 几个基本概念 - 临界区(critical region):访问和操作共享数据的代码段: - 原子操作:操作在执行中不被打断,要么不执行,要么执行完: - 竞争条件: 两个线程 ...

  3. 配置ogg从Oracle到PostgreSQL的同步复制json数据

    标签:goldengate postgresql oracle json 测试环境说明 Oracle:Windows 8.1 + Oracle 12.2.0.1.0 + GoldenGate 12.3 ...

  4. PostgreSQL的同步级别与MySQL的半同步after_sync比较

    MySQL的半同步中通过binlog进行流复制,同步级别和PostgreSQL对比可以发现: PostgreSQL                MySQL off local            ...

  5. postgresql主从同步配置

    前言 不久前,公司的一台物理机器硬件坏了,导致运行在其上的虚拟机都挂了.很不凑巧的是,我负责的那台虚拟机的系统盘坏了(ps:感觉老天在玩我),导致里面的数据永远的离我而去(ps:当时我的内心是崩溃的) ...

  6. java笔记--关于线程同步(7种同步方式)

    关于线程同步(7种方式) --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3897440.html"谢谢-- 为何要使用同步? ...

  7. java笔记--关于线程同步(5种同步方式)【转】

    为何要使用同步?     java允许多线程并发控制,当多个线程同时操作一个可共享的资源变量时(如数据的增删改查),      将会导致数据不准确,相互之间产生冲突,因此加入同步锁以避免在该线程没有完 ...

  8. ASP.NET MVC5学习笔记之Controller同步执行架构分析

    在开始之前,声明一下,由于ASP.NET MVC5正式发布了,后面的分析将基于ASP.NET MVC5最新的源代码.在前面的内容我们分析了怎样根据路由信息来确定Controller的类型,并最终生成C ...

  9. Android(java)学习笔记68:同步代码块 和 同步方法 的应用

    1. 同步代码块 和 同步方法 代码示例: (1)目标类,如下: package cn.himi.text; public class SellTicket implements Runnable { ...

随机推荐

  1. 使用WinSetupFromUSB来U盘安装windowsXP(不使用win PE系统)

    目前用U盘安装XP的多数方法都要借助WINPE,比较麻烦.使用WinSetupFromUSB只需要下载一个6.5MB的绿色软件就可以制作好windows xp的安装U盘,方便简捷. WinSetupF ...

  2. 利用指针突破C++编译器的防线

    C++ 面向对象的一大特性就是封装,使用不同的访问控制符来控制外接对其的访问权限.比如: class A { public: A(): i(){} void print(){ cout << ...

  3. 11417 - GCD

    Problem A GCD Input: Standard Input Output: Standard Output Given the value of N, you will have to f ...

  4. [Leetcode][Python]21: Merge Two Sorted Lists

    # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 21: Merge Two Sorted Listshttps://oj.le ...

  5. poj2350

    #include <stdio.h> #include <stdlib.h> int main() { ],tim,i; scanf("%d",&n ...

  6. html中文乱码

    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">改成<m ...

  7. hdu3280Equal Sum Partitions (区间DP)

    Problem Description An equal sum partition of a sequence of numbers is a grouping of the numbers (in ...

  8. sqlite学习笔记4:表的创建和删除

    前面做了那么多不就是为了数据弄几张表么.接下来看看怎么新建表. 一 新建表 基本的语法例如以下: CREATE TABLE database_name.table_name( column1 data ...

  9. [转]eclipse借助hibernate tool从数据库逆向生成Hibernate实体类

    如何从数据库逆向生成Hibernate实体类呢??? 1. 首先,要在eclipse中采用自带的数据库管理器(Data Management),连通你的数据库: 然后选择数据库,这里用的oracle, ...

  10. 关于使用由CA机构(EJBCA)颁发的证书实现SLLSocket双向认证服务端报null cert chain的解决方案

    在 SSLSocket实现服务端和客户端双向认证的例子 文章中最后提到使用keytool.exe的自签证书实现双向认证可以,但是使用ejbca生成证书实现SLL Socket的双向认证是服务端老是报错 ...