如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin相关的知识,希望对你有一定的参考价值。
参考技术A PostgreSQL是一个强大开源的对象关系类型数据库系统,它能运行于几乎所有主要的操作系统,包括Linux、Unix(AIX、BSD、HP-UX、SGIIRIX、MacOS、Solaris、Tru64)、WindowsOS。在这篇教程里,我们将学习如何在CentOS7/6.5/6.4server中建立PostgreSQL。1.安装PostgreSQL首先根据你的服务器架构添加PostgreSQL库:对CentOS6.x32bit:rpm-Uvhtcpfirewall-cmd--reload3.访问PostgreSQL常用的命令提示符默认情况下数据库名和用户名都是postgres。切换至用户以执行相关操作:su–postgres输入以下命令登陆:psql会有以下样例输出:psql(9.3.5)Type"help"forhelp.Postgres=#可通过输入\q退出postgresql返回命令终端:4.设置用户密码登陆至postgres命令提示符界面su–postgrespsql然后使用命令设置密码postgres=#\passwordpostgresEnternewpassword:Enteritagain:postgres=#\q输入命令以建立PostgreSQL系统管理工具postgres=#CREATEEXTENSIONadminpack;CREATEEXTENSION5.创建用户和数据库例如:用户名:senthil密码:centos数据库名:mydb转到postgres用户su–postgres创建用户senthil$createusersenthil创建数据库$createdbmydb现在登陆至psql提示符界面,为用户senthil设置密码及授权对数据库mydb的访问:$psqlpsql(9.3.5)Type"help"forhelp.postgres=#alterusersenthilwithencryptedpassword'centos';ALTERROLEpostgres=#grantallprivilegesondatabasemydbtosenthil;GRANTpostgres=#6.删除用户和数据库首先转到postgres界面su–postgres输入命令$dropdb删除用户名可输入$dropuser7.配置PostgreSQL-MD5认证MD5认证需要客户端提供一个MD5-encrypted密码以便身份验证。你需要编辑/var/lib/pgsql/9.3/data/pg_hba.conf文件:vi/var/lib/pgsql/9.3/data/pg_hba.conf添加或修改的行如下:[]#TYPEDATABASEUSERADDRESSMETHOD#"local"isforUnixdomainsocketconnectionsonlylocalallallmd5#IPv4localconnections:hostallall127.0.0.1/32md5hostallall192.168.1.0/24md5#IPv6localconnections:hostallall::1/128md5[]重启postgresql服务以应用更改在CentOS6.x系统中servicepostgresql-9.3restart在CentOS7系统中systemctlrestartpostgresql-9.38.配置PostgreSQL-ConfigureTCP/IP默认情况下,TCP/IP连接是不可行的,所以其他计算机用户不能连接到postgresql。编辑文件/var/lib/pgsql/9.3/data/postgresql.conf可以允许连接:vi/var/lib/pgsql/9.3/data/postgresql.conf找到下面的行:[]#listen_addresses='localhost’[]#port=5432[]把两行都取消并设置为你的postgresql服务器IP地址或设置为“*”监听所有客户端。如下所示:listen_addresses='*'port=5432重启以应用更改在CentOS6.x系统中:/etc/init.d/postgresql-9.3restart在CentOS7系统中:systemctlrestartpostgresql-9.39.使用phpPgAdmin管理PostgreSQLphpPgAdmin是使用PHP编写的基于web的管理工具,用于管理PostgreSQL。它只适用与PostgreSQLRPM库。如果你没有添加PostgreSQL库,你可以添加EPEL库。可根据下面的链接在CentOS6.x中建立EPEL库如何在 CentOS 7 上安装 Docker
1. 为centos配置yum源, 可以使用网易、aliyun或sohu的2. 配置epel源
/etc/yum.repos.d/epel.repo
[epel]
name=Extra Packages for Enterprise Linux 6 - $basearch
baseurl=http://centos.ustc.edu.cn/epel/6/$basearch
failovermethod=priority
enabled=1
gpgcheck=0
注: 选择其他的epel源也可以
3. 使配置生效
yum clean all
yum makecache
三 安装docker并启动
A)安装
Yum install docker-io
B)启动
Service dokcer start
C)检查
Ps aux |grep docker ,查看是否有 "/usr/bin/docker -d"进程存在
执行Docker images 没有报错
D) 把dokcer的数据目录转移到大的磁盘分区上, 不是必须的,视自己的机器分区而定
Service docker stop
Mkdir /data/dockerData/
Mv /var/lib/docker /data/dockerData/
ln -s /data/dockerData/docker /var/lib/dockerService docker start
Service docker start
四 搭建docker私有仓库并制作centos镜像
1. 搭建docker私有仓库
安装并启动
Yum install docker-registry
修改配置
把/var/lib/docker-registry 软连接到
大的磁盘分区, 不是必须的,视自己的机器分区而定
修改配置/etc/sysconfig/docker-registry, 只监听内网的5000端口
修改配置/etc/docker-registry.yml 中search_backend和
sqlalchemy_index_database,修改目的是可以通过 curl
"x.x.x.x:5000/v1/search?q=xxx" 查询仓库镜像。
#search_backend: _env:SEARCH_BACKEND
search_backend: sqlalchemy
#sqlalchemy_index_database: _env:SQLALCHEMY_INDEX_DATABASE:sqlite:////tmp/docker-registry.db
sqlalchemy_index_database: sqlite:////tmp/docker-registry.db
启动
Service docker-registry restart
检查下端口5000是否启动起来 netstat -ntlp
2. 制作centos镜像
这一步不是必须的,可用如下方案替换:
1)从docker的官方镜像库拉取contos的镜像,
然后再import到自己搭建的私有仓库。但docker的官方镜像库被墙了,需要自备梯子。
2)Docker官方镜像的临时解决方案
使用 index.dockboard.org 下载 Docker 官方镜像的临时解决方案
https://gist.github.com/genedna/6e552ab4c117f7ba8af4
除了上述两种方案, 这里讲如何定制自己centos镜像,仅供测试docker使用。
A) 安装软件
yum -y install febootstrap
B)下载镜像
febootstrap -i bash -i wget -i yum -i iputils -i iproute -i man -i vim-minimal -i openssh-server -i openssh-clients centos6 centos6-image http://mirrors.aliyun.com/centos/6/os/x86_64/
C) 生成镜像
cd centos6-image && tar -c . |docker import - xxx/centos-base
查看镜像是否已经有xxx/centos-base
docker images
D) 运行测试
测试镜像是否正常
docker run -i -t xx/centos-base /bin/bash
E) 把制作的镜像添加到私有的docker仓库
Docker image 获取IMAGE ID
使用私有的docker仓库的ip:端口给该镜像打tag
docker tag 1920ceab1c8b xx.xx.xx.xx:5000/xxx/centos-base
推送该镜像到仓库
docker push xx.xx.xx.xx:5000/xxx/centos-base
F) 在另一台机器上可以拉取该镜像并运行 docker pull
xx.xx.xx.xx:5000/xxx/centos-base
docker images
docker run -t -i xx.xx.xx.xx:5000/xxx/centos-base /bin/bash
五 简单测试
1. 从私有仓库拉取镜像
Docker pull xx.xx.xx.xx:5000/xxx/centos-base
查看镜像ID
docker images
根据ID给该镜像起一个简短名字
Docker tag 1920ceab1c8b xxx/centos-base
运行一个简单的container, 并把container ID传给变量JOB, 后续操作都依赖于该container ID
JOB=$(docker run -d xxx/centos-base /bin/bash -c "while true; do /bin/echo Hello world; /bin/sleep 1; done")
查看container 是否正常启动
Docker ps
查看运行日志
Docker logs $JOB
停止进程
Docker stop $JOB
查看container 是否已停止
Docker ps 参考技术A 1. 为centos配置yum源, 可以使用网易、aliyun或sohu的
2. 配置epel源
/etc/yum.repos.d/epel.repo
[epel]
name=Extra Packages for Enterprise Linux 6 - $basearch
failovermethod=priority
enabled=1
gpgcheck=0
注: 选择其他的epel源也可以
3. 使配置生效
yum clean all
yum makecache
三 安装docker并启动
A)安装
Yum install docker-io
B)启动
Service dokcer start
C)检查
Ps aux |grep docker ,查看是否有 "/usr/bin/docker -d"进程存在
执行Docker images 没有报错
D) 把dokcer的数据目录转移到大的磁盘分区上, 不是必须的,视自己的机器分区而定
Service docker stop
Mkdir /data/dockerData/
Mv /var/lib/docker /data/dockerData/
ln -s /data/dockerData/docker /var/lib/dockerService docker start
Service docker start
四 搭建docker私有仓库并制作centos镜像
1. 搭建docker私有仓库
安装并启动
Yum install docker-registry
修改配置
把/var/lib/docker-registry 软连接到
大的磁盘分区, 不是必须的,视自己的机器分区而定
修改配置/etc/sysconfig/docker-registry, 只监听内网的5000端口
修改配置/etc/docker-registry.yml 中search_backend和
sqlalchemy_index_database,修改目的是可以通过 curl
"x.x.x.x:5000/v1/search?q=xxx" 查询仓库镜像。
#search_backend: _env:SEARCH_BACKEND
search_backend: sqlalchemy
#sqlalchemy_index_database: _env:SQLALCHEMY_INDEX_DATABASE:sqlite:////tmp/docker-registry.db
sqlalchemy_index_database: sqlite:////tmp/docker-registry.db
启动
Service docker-registry restart
检查下端口5000是否启动起来 netstat -ntlp
2. 制作centos镜像
这一步不是必须的,可用如下方案替换:
1)从docker的官方镜像库拉取contos的镜像,
然后再import到自己搭建的私有仓库。但docker的官方镜像库被墙了,需要自备梯子。
2)Docker官方镜像的临时解决方案
使用 index.dockboard.org 下载 Docker 官方镜像的临时解决方案
除了上述两种方案, 这里讲如何定制自己centos镜像,仅供测试docker使用。
A) 安装软件
yum -y install febootstrap
B)下载镜像
febootstrap -i bash -i wget -i yum -i iputils -i iproute -i man -i vim-minimal -i openssh-server -i openssh-clients centos6 centos6-image
C) 生成镜像
cd centos6-image && tar -c . |docker import - xxx/centos-base
查看镜像是否已经有xxx/centos-base
docker images
D) 运行测试
测试镜像是否正常
docker run -i -t xx/centos-base /bin/bash
E) 把制作的镜像添加到私有的docker仓库
Docker image 获取IMAGE ID
使用私有的docker仓库的ip:端口给该镜像打tag
docker tag 1920ceab1c8b xx.xx.xx.xx:5000/xxx/centos-base
推送该镜像到仓库
docker push xx.xx.xx.xx:5000/xxx/centos-base
F) 在另一台机器上可以拉取该镜像并运行 docker pull
xx.xx.xx.xx:5000/xxx/centos-base
docker images
docker run -t -i xx.xx.xx.xx:5000/xxx/centos-base /bin/bash
五 简单测试
1. 从私有仓库拉取镜像
Docker pull xx.xx.xx.xx:5000/xxx/centos-base
查看镜像ID
docker images
根据ID给该镜像起一个简短名字
Docker tag 1920ceab1c8b xxx/centos-base
运行一个简单的container, 并把container ID传给变量JOB, 后续操作都依赖于该container ID
JOB=$(docker run -d xxx/centos-base /bin/bash -c "while true; do /bin/echo Hello world; /bin/sleep 1; done")
查看container 是否正常启动
Docker ps
查看运行日志
Docker logs $JOB
停止进程
Docker stop $JOB
查看container 是否已停止
Docker ps 参考技术B Docker 是一个开源工具,它可以让创建和管理 Linux 容器变得简单。容器就像是轻量级的虚拟机,并且可以以毫秒级的速度来启动或停止。Docker 帮助系统管理员和程序员在容器中开发应用程序,并且可以扩展到成千上万的节点。
容器和 VM(虚拟机)的主要区别是,容器提供了基于进程的隔离,而虚拟机提供了资源的完全隔离。虚拟机可能需要一分钟来启动,而容器只需要一秒钟或更短。容器使用宿主操作系统的内核,而虚拟机使用独立的内核。
以上是关于如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin的主要内容,如果未能解决你的问题,请参考以下文章
如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin
如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin
如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin
如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 phpPgAdmin