跳至主要内容

PostgreSQL 入门


https://dinfratechsource.com/2018/11/10/installing-postgresql-9-4-phppgadmin-in-centos-7/


       初次安装后,默认生成一个名为postgres的数据库和一个名为postgres的数据库管理员用户,密码随机。这里需要注意的是,同时还生成了一个名为postgres的Linux系统用户

[root@kpsA ~]# cat /etc/passwd|grep postgres
postgres:x:26:26:PostgreSQL Server:/var/lib/pgsql:/bin/bash

修改linux系统postgres用户的密码

步骤一:删除用户postgres的密码
[root@kpsA ~]# sudo passwd -d postgres
Removing password for user postgres.
passwd: Success
步骤二:设置用户postgres的密码,根据系统提示输入新的密码
[root@kpsA ~]# sudo -u postgres passwd
Changing password for user postgres.
New password: 
Retype new password: 
passwd: all authentication tokens updated successfully.


# Linux登录用户切换到postgres用户sudo su - postgres,退出exit|logout
[root@kpsA ~]# sudo su - postgres
Last login: Mon Nov 11 16:11:30 CST 2019 on pts/3

# 使用psql命令登录PostgreSQL控制台
-bash-4.2$ psql
psql (9.2.13)
输入 "help" 来获取帮助信息.


# 登录还可以用sudo -u postgres psql 或者 psql -U postgres
# 相当于系统用户postgres以同名数据库用户的身份,登录数据库,这是不用输入密码的。如果一切正常,系统提示符会变为"postgres=#",数据库为=#表示这时已经进入了数据库控制台

当前数据库中所有表信息
select * from pg_tables;

查看数据库信息
select version();

postgres=# help
您正在使用psql, 这是一种用于访问PostgreSQL的命令行界面
键入: \copyright 显示发行条款
       \h 显示 SQL 命令的说明
       \? 显示 pgsql 命令的说明
       \g 或者以分号(;)结尾以执行查询
       \q 退出


postgres=# \?
一般性
  \copyright            显示PostgreSQL的使用和发行许可条款
  \g [文件] or;     执行查询 (并把结果写入文件或 |管道)
  \h [名称]          SQL命令语法上的说明,用*显示全部命令的语法说明
  \q             退出 psql

查询缓存区
  \s [文件]        显示历史记录或将历史记录保存在文件中
postgres-# \s
select version():
...

  \w 文件          将查询缓存区的内容写入文件


资讯性
  (选项: S = 显示系统对象, + = 其余的详细信息)
  \db[+]  [模式]     列出表空间
postgres-# \db
                                       List of tablespaces
          Name          |         Owner          |                   Location                    
------------------------+------------------------+-----------------------------------------------
 FWKP_310100000000002_5 | fwkp_310100000000002_5 | /var/lib/pgsql/data/TS_FWKP_310100000000002_5
 pg_default             | postgres               | 
 pg_global              | postgres               | 
(3 rows)

postgres-# \db[+]
                                                        List of tablespaces
          Name          |         Owner          |                   Location                    | Access privileges | Description 
------------------------+------------------------+-----------------------------------------------+-------------------+-------------
 FWKP_310100000000002_5 | fwkp_310100000000002_5 | /var/lib/pgsql/data/TS_FWKP_310100000000002_5 |                   | 
 pg_default             | postgres               |                                               |                   | 
 pg_global              | postgres               |                                               |                   | 

(3 rows)

  \du[+]  [PATTERN]      列出角色
postgres-# \du
                                    List of roles
       Role name        |                   Attributes                   | Member of 
------------------------+------------------------------------------------+-----------
 fwkp_310100000000002_5 | Create role, Create DB                         | {}
 postgres               | Superuser, Create role, Create DB, Replication | {}

postgres-# \du[+]
                                           List of roles
       Role name        |                   Attributes                   | Member of | Description 
------------------------+------------------------------------------------+-----------+-------------
 fwkp_310100000000002_5 | Create role, Create DB                         | {}        | 

 postgres               | Superuser, Create role, Create DB, Replication | {}        | 



  \l[+]                列出所有的数据库
postgres-# \l
                                               List of databases
          Name          |         Owner          | Encoding |   Collate   |    Ctype    |   Access privileges   
------------------------+------------------------+----------+-------------+-------------+-----------------------
 fwkp_310100000000002_5 | fwkp_310100000000002_5 | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | 
 postgres               | postgres               | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | 
 template0              | postgres               | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/postgres          +
                        |                        |          |             |             | postgres=CTc/postgres
 template1              | postgres               | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/postgres          +
                        |                        |          |             |             | postgres=CTc/postgres
(4 rows)


我们可以使用 \c + 数据库名 来进入数据库连接
  \c[onnect] {[DBNAME|- USER|- HOST|- PORT|-] | conninfo}
                         connect to new database (currently "postgres")
postgres-# \c
You are now connected to database "postgres" as user "postgres".
  \encoding [编码名称] 显示或设定客户端编码
postgres-# \encoding
UTF8
  \password [USERNAME]  安全地为用户改变口令
postgres=# \password postgres
Enter new password: 
Enter it again: 
  \conninfo              显示当前连接的相关信息
postgres=# \conninfo

You are connected to database "postgres" as user "postgres" via socket in "/var/run/postgresql" at port "5432".


变量
  \set [名称 [值数]] 设定内部变量,若无参数则列出全部变量
postgres=# \set
AUTOCOMMIT = 'on'
PROMPT1 = '%/%R%# '
PROMPT2 = '%/%R%# '
PROMPT3 = '>> '
VERBOSITY = 'default'
VERSION = 'PostgreSQL 9.2.13 on x86_64-redhat-linux-gnu, compiled by gcc (GCC) 4.8.3 20140911 (Red Hat 4.8.3-9), 64-bit'
DBNAME = 'postgres'
USER = 'postgres'
PORT = '5432'
ENCODING = 'UTF8'



外机pgAdmin访问postgres


修改数据库管理员PostgreSQL密码

登录数据库psql -U postgres
方法一:
postgres=# alter user postgres with password 'postgres';
ALTER ROLE
方法二:
postgres=# \password postgres
Enter new password: 
Enter it again: 


修改postgresql.conf文件

查找postgresql.conf文件位置
[root@kpsA ~]# find / -name 'postgresql.conf'
/usr/lib/tmpfiles.d/postgresql.conf
/var/lib/pgsql/data/postgresql.conf
[root@kpsA ~]# vi /var/lib/pgsql/data/postgresql.conf

在连接设置下编辑或添加一行listen_addresses = '*',使PostgreSQL可以接受来自任意IP的连接请求
# - Connection Settings -

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)
# Note: In RHEL/Fedora installations, you can't set the port number here;


修改pg_hba.conf文件
pg_hba.conf,位置与postgresql.conf相同,虽然上面配置允许任意地址连接PostgreSQL,但是这在pg中还不够,我们还需在pg_hba.conf中配置服务端允许的认证方式。任意编辑器打开该文件,编辑或添加下面一行。修改为上面内容后即可以对任意IP访问进行密码验证

[root@kpsA ~]# vi /var/lib/pgsql/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            md5
host    all             all             0.0.0.0/0            md5
# IPv6 local connections:
host    all             all             ::1/128                 ident
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local   replication     postgres                                peer
#host    replication     postgres        127.0.0.1/32            ident
#host    replication     postgres        ::1/128                 ident




在防火墙上将PostgreSQL监听的端口放开
firewall-cmd --zone=public --add-port=5432/tcp --permanent
firewall-cmd --reload
firewall-cmd --list-ports
systemctl restart firewalld

执行完以上操作后,运行systemctl restart postgresql重启PostgreSQL服务后,允许外网访问的配置就算生效了


评论

此博客中的热门博文

Mongo 入门

https://pymongo.readthedocs.io/en/stable/tutorial.html https://www.mongodb.com/languages/python https://zhuanlan.zhihu.com/p/51171906 https://www.runoob.com/python3/python-mongodb.html https://blog.baoshuo.ren/post/luogu-spider/ https://hub.docker.com/_/mongo 安装 MongoDB $ docker search mongo 启动一个mongo服务器实例 $ docker run --name some-mongo -d mongo:tag some-mongo是您要分配给容器的名称,tag是指定您想要的 MongoDB 版本的标签 MongoDB 的默认数据目录路径是/data/db 如下: $ docker run -it -v mongodata:/data/db -p 27017:27017 --name mongodb --restart unless-stopped -d mongo 你应该让 MongoDB 在端口 27017 上运行,并且可以通过localhostWindows 和 Ubuntu 20.04 上的URL访问 http://localhost:27017/ -p 是 HOST_PORT:CLIENT_PORT  -P 随机端口 -p 27017:27017 :将容器的27017 端口映射到主机的27017 端口 -v mongodata:/data/db :将主机中当前目录下的db挂载到容器的/data/db,作为mongo数据存储目录 从另一个 Docker 容器连接到 MongoDB 镜像中的 MongoDB 服务器侦听标准 MongoDB 端口27017,因此通过 Docker 网络连接将与连接到远程mongod. 以下示例启动另一个 MongoDB 容器实例,并mongo针对上述示例中的原始 MongoDB 容器运行命令行客户端,从而允许您针对数据库实例执行 MongoDB 语句: $ docker run -it --network some-network --...

端口映射 公网访问内网

https://portforward.com/ Holer 通过安全隧道将位于NAT和防火墙之后的本地服务器暴露给公共Internet。 Holer是一个将原型中的应用映射到公网访问的端口映射软件,支持转发基于TCP协议的报文 https://github.com/wisdom-projects/holer 方式一:使用(公告)的holer映射或者开通holer服务,通过holer客户端软件经 holer服务器实现公网访问。 公开的holer映射详情如下: 访问密钥 访问域名 公网地址 本地地址 使用场景 HOLER_CLIENT-2F8D8B78B3C2A0AE holer65530.wdom.net holer.org:65530 127.0.0.1:8080 网页 HOLER_CLIENT-3C07CDFD1BF99BF2 holer65531.wdom.net holer.org:65531 127.0.0.1:8088 网页 HOLER_CLIENT-2A623FCB6E2A7D1D holer65532.wdom.net holer.org:65532 127.0.0.1:80 网页 HOLER_CLIENT-AF3E6391525F70E4 不适用 holer.org:65533 127.0.0.1:3389 远程桌面 HOLER_CLIENT-822404317F9D8ADD 不适用 holer.org:65534 127.0.0.1:22 SSH协议 HOLER_CLIENT-27DD1389DF1D4DBC 不适用 holer.org:65535 127.0.0.1:3306 数据库 使用Java版本的holer客户端 ①java 1.7或者更高版本 ②下载holer-client.zip 修改配置文件C:\holer-client\conf\holer.conf HOLER_ACCESS_KEY=HOLER_CLIENT-2A623FCB6E2A7D1D HOLER_SERVER_HOST=holer65532.wdom.net ③建议先双击运行C:\holer-client\bin\shutdown.bat,再双击运行C:\holer-client\bin\startup.bat...

安装和卸载软件(msi\exe)

如何判断一个软件是64位的还是32位的? 情况1、 未安装--右键安装程序查看属性,兼容性,勾选兼容模式查看最低适配是vista的是64位,反之32位, 不太准确 情况2、 已安装--运行软件,64位操作系统打开任务管理器看进程后缀名,带*32就是32位,反之64位 https://www.joci.net/xxbk/126251/ FileMon 和 Regmon 不再可供下载。从Windows 2000 SP4,Windows XP SP2,Windows Server 2003 SP1和Windows Vista开始的Windows版本上,它们已被 Process Monitor 取代 https://adamtheautomator.com/procmon/ Process Monitor 是Windows的高级监视工具,它显示实时文件系统,注册表和进程/线程活动。 它结合了两个旧的Sysinternals实用程序 Filemon 和  Regmon的功能 ,并添加了广泛的增强功能列表,包括丰富的和非破坏性的过滤,全面的事件属性(例如会话ID和用户名),可靠的过程信息,带有集成符号的完整线程堆栈支持每个操作,同时记录到文件等。 它独特的强大功能将使Process Monitor成为您的系统故障排除和恶意软件搜索工具包中的核心实用程序。 https://wikileaks.org/ciav7p1/cms/page_42991626.html HKLM\Software\Microsoft\Cryptography\MachineGuid Machine GUID/Cryptography GUID---该密钥通常用作机器的唯一标识符。它也已用于将两台计算机链接在一起-在某些情况下,计算机GUID是与设备(MP3播放器等)一起传递的。 Machine GUID不是唯一 https://docs.microsoft.com/zh-cn/windows/win32/properties/props-system-identity-uniqueid?redirectedfrom=MSDN UniqueID才是唯一 注册表 是存储系统和应用程序的设置信息 打开注册表的方式很简单:cmd中输入regedit 卸载路径只有一个 已安装32位的程序,如果是系统是32位...