PostgreSQL使用安装

一. 安装

ubuntu安装:

# 安装客户端
sudo apt-get install postgresql-client
# 安装服务器
sudo apt-get install postgresql
# 安装图形界面
sudo apt-get install pgadmin3

安装后默认生成一个名为postgres的数据库和一个名为postgres的数据库用户。这里需要注意的是,同时还生成了一个名为postgres的Linux系统用户。

二. 登录

# 先切换到postgres用户
sudo su postgres

以下命令相当于系统用户postgres以同名数据库用户的身份

psql

完整登录命令

psql -U dbuser -d exampledb -h 127.0.0.1 -p 5432

上面命令的参数含义如下:-U指定用户,-d指定数据库,-h指定服务器,-p指定端口。

三. 授权其他用户

授权其他用户登录:

# 新建系统用户
sudo adduser superpika # 进入控制台
psql

先改下命令:

\password postgres

创建用户,和新建系统用户一样:

CREATE USER superpika WITH PASSWORD 'password';

新建数据库并授权:

CREATE DATABASE exampledb OWNER superpika;
GRANT ALL PRIVILEGES ON DATABASE exampledb to superpika;

控制台输入\q退出:

\q

退出后,重新登录,命令需完整!

exit
psql -U superpika -d exampledb -h 127.0.0.1 -p 5432

四. 远程登录

vim /etc/postgresql/9.5/main/postgresql.conf

listen_addresses = '*'  

vim /etc/postgresql/9.5/main/pg_hba.conf

host    all             all             127.0.0.1/32            md5
host all all 0.0.0.0/0 md5 # 如果想指定数据库的话,需要修改第一个 all,如果需要指定用户的话,修改第二个all sudo /etc/init.d/postgresql restart

五. 命令

除了前面已经用到的\password命令(设置密码)和\q命令(退出)以外,控制台还提供一系列其他命令。

    \h:查看SQL命令的解释,比如\h select。
\?:查看psql命令列表。
\l:列出所有数据库。
\c [database_name]:连接其他数据库。
\d:列出当前数据库的所有表格。
\d [table_name]:列出某一张表格的结构。
\du:列出所有用户。
\e:打开文本编辑器。
\conninfo:列出当前数据库和连接的信息。

基本的数据库操作,就是使用一般的SQL语言。

# 创建新表
CREATE TABLE user_tbl(name VARCHAR(20), signup_date DATE); # 插入数据
INSERT INTO user_tbl(name, signup_date) VALUES('张三', '2013-12-22'); # 选择记录
SELECT * FROM user_tbl; # 更新数据
UPDATE user_tbl set name = '李四' WHERE name = '张三'; # 删除记录
DELETE FROM user_tbl WHERE name = '李四' ; # 添加栏位
ALTER TABLE user_tbl ADD email VARCHAR(40); # 更新结构
ALTER TABLE user_tbl ALTER COLUMN signup_date SET NOT NULL; # 更名栏位
ALTER TABLE user_tbl RENAME COLUMN signup_date TO signup; # 删除栏位
ALTER TABLE user_tbl DROP COLUMN email; # 表格更名
ALTER TABLE user_tbl RENAME TO backup_tbl; # 删除表格
DROP TABLE IF EXISTS backup_tbl;

备份:

1.只导出结构

    #!/usr/bin/env bash
## -h 主机名
## -U 用户名
## -W 强制输入密码
## -d 数据库名字
## -t 表名字
## -s 导出schema,不导出数据
## -C 创建数据库并连接数据库
## -f 数据文件
pg_dump -v -h 127.0.0.1 -U postgres -W -d postgres1 -t public.job -s -C -f init_pg.sql #!/usr/bin/env bash
psql -v -h 127.0.0.1 -U postgres -W -d postgres -t public.job -f init_pg.sql

2.正常备份:将osdba数据库整个导出

    pg_dump -v -h 127.0.0.1 -U postgres osdba -Fc > osdba.dump

    #  -C表示通过-d后面的数据库进入,然后创建osdba数据库。。。
pg_restore -v -h 127.0.0.1 -U postgres -C -d postgres osdba.dump # 从模板创建数据库,并导入
createdb -T template0 osdba2
pg_restore -d osdba2 osdba.dump

六. 连接数爆了

Connection could not be allocated because: FATAL: sorry, too many clients alread

查找配置文件还有连接数:

postgres=# SHOW config_file;
config_file
------------------------------------------
/etc/postgresql/9.5/main/postgresql.conf
(1 row) postgres=# select count(1) from pg_stat_activity;
count
-------
74
(1 row)

编辑

vim  /etc/postgresql/9.5/main/postgresql.conf

max_connections=6000

sudo /etc/init.d/postgresql restart

扩大linux的文件描述符

一,通过ulimit命令修改

//显示当前文件描述符
ulimit -n //修改当前用户环境下的文件描述符为65536
ulimit -HSn 65536 echo "ulimit -HSn 65536" >> /etcrc.local 使用ulimit命令的缺点: 1,只能修改当前登录用户环境下的文件描述符,如果此用户来另外打开一个连接,此链接环境的文件描述符依然是没改前的
2,如果系统重启,以前修改都不再生效 二,通过修改limits.conf文件 编辑/etc/security/limits.conf 文件,在最后加入如下两行 * soft nofile 65536
* hard nofile 65536 保存退出,都不需要重启服务器,直接重新登陆!!!!用ulimit -n就能看到效果 这样无论使用哪个用户,无论是否重启都不会失效了。

PostgreSQL使用安装的更多相关文章

  1. Mac 下 PostgreSQL 的安装与使用

    在 mac 下,可以利用 homebrew 直接安装 PostgreSQL: 1 brew install postgresql -v 稍等片刻,PostgreSQL 就安装完成.接下来就是初始数据库 ...

  2. Linux下的PostgreSQL简单安装手册

    1. 安装环境     linux版本: CentOS release 6.2 (Final)     pg版本    : postgresql-9.5.0   2. pg数据库下载地址 --http ...

  3. CentOS 6.3下PostgreSQL 的安装与配置

    一.简介 PostgreSQL 是一种非常复杂的对象-关系型数据库管理系统(ORDBMS),也是目前功能最强大,特性最丰富和最复杂的自由软件数据库系统.有些特性甚至连商业数据库都不具备.这个起源于伯克 ...

  4. postgresql编译安装与调试(二)

    接前文postgresql编译安装与调试(一),继续说说postgresql的编译安装与调试. 上一篇已经详细说明了如何在Linux系统上编译安装postgresql,这次我们在此基础上简单讲讲如何在 ...

  5. [转] Mac 下 PostgreSQL 的安装与使用

    在 mac 下,可以利用 homebrew 直接安装 PostgreSQL: 1 brew install postgresql -v 稍等片刻,PostgreSQL 就安装完成.接下来就是初始数据库 ...

  6. postgresql数据库安装及简单操作

    自从MySQL被Oracle收购以后,PostgreSQL逐渐成为开源关系型数据库的首选. 本文介绍PostgreSQL的安装和基本用法,供初次使用者上手.以下内容基于Debian操作系统,其他操作系 ...

  7. PostgreSQL+PostGIS安装以及使用

    安装,参照:    https://www.cnblogs.com/ytwy/p/6817179.html 创建企业级地理文件数据库时报错," You must copy the lates ...

  8. PostgreSQL编译安装

    PostgreSQL编译安装 安装语言包 ### PostgreSQL 初始化过程中,会读取操作系统字符编码, ### 若程序需要使用zh_CN.utf-8字符编码,需要在PostgreSQL 初始化 ...

  9. postgresql编译安装与调试(一)

    因为最近组里的项目和postgresql有关,并且需要查看和调试源码,所以专门学习了一下如何安装和调试postgresql,此博文用来记录自己的安装和调试过程.安装环境是CentOS6(CentOS7 ...

  10. Linux——CentOS 6.3下PostgreSQL 的安装与配置

    一.简介 PostgreSQL 是一种非常复杂的对象-关系型数据库管理系统(ORDBMS),也是目前功能最强大,特性最丰富和最复杂的自由软件数据库系统.有些特性甚至连商业数据库 都不具备.这个起源于伯 ...

随机推荐

  1. 搭建Android+QT+OpenCV环境,实现“单色图片着色”效果

               OpenCV是我们大家非常熟悉的图像处理开源类库:在其新版本将原本在Contrib分库中的DNN模块融合到了主库中,并且更新了相应文档.这样我们就能够非常方便地利用OpenCV实 ...

  2. sql server 中常用修改列 ,创建主外键操作

    表结构 CREATE TABLE [staff] ( [id] [varchar](50) NOT NUL L, [name] [varchar](50) NOT NULL, [password] [ ...

  3. 痞子衡嵌入式:飞思卡尔i.MX RTyyyy系列MCU硬件那些事(1)- 官方EVK简介

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RTyyyy系列MCU的配套EVK板. 半导体设计厂商发布任何一块MCU芯片新品,一般都会同步推出基于这款MCU的配套 ...

  4. 使用Storm进行词频统计

    词频统计 1.需求:读取指定目录的数据,并且实现单词计数功能 2.实现方案: Spout用于读取指定文件夹(目录),读取文件,将文件的每一行发射到Bolt SplitBolt用于接收Spout发射过来 ...

  5. Apache和Tomcat 配置负载均衡(mod-proxy方式)-粘性session

    Tomcat集群配置后端Tomcat Server为支持AJP的独立服务,前端Apache配置为粘性会话(sticky-session),Tomcat不配置Cluster配置和Session复制. 配 ...

  6. 【ADO.NET基础-Regidter】简单的账户注册界面和源代码(可用于简单面试基础学习用)

    在阅读时如有问题或者建议,欢迎指出和提问,我也是初学者......... 前台代码: <!DOCTYPE html> <html xmlns="http://www.w3. ...

  7. jQuery常用方法(二)-事件

    ready(fn); $(document).ready()注意在body中没有onload事件,否则该函数不能执行.在每个页面中可以 有很多个函数被加载执行,按照fn的顺序来执行. bind( ty ...

  8. .Net Core 商城微服务项目系列(十):使用SkyWalking构建调用链监控(2019-02-13 13:25)

    SkyWalking的安装和简单使用已经在前面一篇介绍过了,本篇我们将在商城中添加SkyWalking构建调用链监控. 顺带一下怎么把ES设置为Windows服务,cd到ES的bin文件夹,运行ela ...

  9. 二次编码 深浅拷贝 is和==

    1.二次编码 ascii 不支持中文 gbk 支持中文 2个字节 包含ascii Unicode 万国码 python3 内存Unicode utf-8 可变的长度 英文 1字节 欧洲2个字节 亚洲3 ...

  10. 【Java基础】Java中的语法糖

    目录 Java中的语法糖 switch对String和枚举类的支持 对泛型的支持 包装类型的自动装箱和拆箱 变长方法参数 枚举 内部类 条件编译 断言 数值字面量 for-each try-with- ...