https://www.postgresql.org/ftp/source/
创建用户组
#创建用户
useradd postgres
#设置密码
passwd postgres
进行源码安装 以安装到 目录下为例 /usr/local/pg
1 解压
tar -xvf postgresql-14.5.tar.gz -C /usr/local/
以上命令就是解压到哪个目录下,目前是解压到/usr/local/ 下
##2.yum依赖
yum install -y gcc gcc-c++
yum install -y readline-devel
yum install -y zlib-devel
##3.编绎,并安装到/opt/postgresql目录
mkdir /opt/postgresql
cd /opt/postgresql-14.5
./configure --prefix=/opt/postgresql
make
make install
#4.准备数据目录
mkdir -p /usr/local/pg/pgsqldata
chown -R postgres:postgres /usr/local/pg/pgsqldata
#5.切换到postgres用户
su postgres
#初始化数据库
/usr/local/pg/bin/initdb -D /usr/local/pg/pgsqldata
mkdir /usr/local/pg/pgsqldata/logs
#启动
/usr/local/pg/bin/pg_ctl -D /usr/local/pg/pgsqldata -l /usr/local/pg/pgsqldata/logs/pgsql.log start
/usr/local/pg/bin/createdb test #创建测试库
/usr/local/pg/bin/psql test #进入数据库
#6.修改管理员密码
ALTER USER postgres WITH PASSWORD '060708';
su postgres
/usr/local/pg
./bin/psql -h 127.0.0.1 -d test -U postgres -p 5432
关闭 数据库
su postgres
/usr/local/pg/bin/pg_ctl -D /usr/local/pg/pgsqldata -l /usr/local/pg/pgsqldata/logs/pgsql.log stop
- 开启远程访问
####修改postgresql.conf文件,取消 listen_addresses 的注释,将参数值改为“*”
####修改pg_hba.conf文件,增加下图红框部分内容
host all all 0.0.0.0/0 md5
####navicat
postgresql.conf 这个配置是在/usr/local/pg/pgsqldata 这个目录下 pg_hba.conf文件 这个配置是在/usr/local/pg/pgsqldata 这个目录下
创建数据库的用户,并且赋予密码
CREATE USER admin WITH PASSWORD '060708';
#6.修改管理员密码
ALTER USER postgres WITH PASSWORD '060708';
展示当前数据库的用户名密码
SELECT usename, passwd FROM pg_shadow;
创建server
[Unit]
Description=PostgreSQL Database Server
Documentation=man:postgres(1)
[Service]
ExecStart=/usr/local/pg/bin/pg_ctl -D /usr/local/pg/pgsqldata
ExecReload=/bin/kill -HUP $MAINPID
KillMode=mixed
KillSignal=SIGINT
TimeoutSec=300
[Install]
WantedBy=default.target
/etc/systemd/system/
这个目录下 ,是 存放service 文件的地方
postgreSql
加载镜像
docker load -i postgresql.tar
- 在宿主机找一个地方,存放数据库的数据
docker load -i postgresql.tar
version: '3'
services:
db:
image: kartoza/postgis:11.0-2.5
container_name: pgadmin
restart: always
ports:
- "15432:5432"
volumes:
- /home/softinstall/docker/pg/data:/var/lib/postgresql/data
environment:
- TZ=Asia/Shanghai
- POSTGRES_PASSWORD=123456
- POSTGRES_USER=your_username
# 在这个pg.yml 文件夹下,执行下面就启动了
docker-compose -f pg.yml up -d
# 查看日志
docker logs -f pgadmin
# 关闭容器
docker-compose -f pg.yml down
# 如果第一次启动失败,要修改完配置文件之后,关闭之后重新启动
# 先执行
docker-compose -f pg.yml down
# 后执行
docker-compose -f pg.yml up -d
docker exec -it 容器id /bin/bash
docker exec -it pgadmin psql -U root -d postgres
1 是否安装docker
2 是否安装docker-compose
3 docker默认镜像存放地址在/var/lib/docker 目录下,查看此目录下是否有足够的空间
df -h 目录名 查看所在目录 挂载目录及使用情况
4 查看机器,生成数据的存储空间
dh -h
5 检查是否系统是否为x86系统内核,( 部署包内的 java8镜像,smb软件 只支持x86系统)
uname -a
相关知识点
2.1 docker默认镜像存放地址
在Linux系统上,Docker默认将镜像存储在/var/lib/docker
目录下。这个目录包含了Docker的运行时数据,包括镜像、容器、卷等。
在/var/lib/docker
目录下,镜像的具体存放位置如下:
- 镜像层(Image Layers):
/var/lib/docker/image/overlay2
目录下存放了镜像的各个层。 - 镜像元数据(Image Metadata):
/var/lib/docker/image/overlay2/repositories.json
文件包含了镜像的元数据信息,如镜像的名称、标签等。
请注意,/var/lib/docker
目录下的文件和目录属于Docker的运行时数据,对其进行修改或删除可能会导致Docker的不稳定或数据丢失。如果你需要备份或迁移Docker的镜像数据,建议使用Docker提供的相关命令或工具来操作。
此外,值得一提的是,Docker的存储驱动可以根据不同的配置进行更改,因此实际的镜像存放位置可能会因配置而异。但对于大多数默认安装的Docker环境来说,/var/lib/docker
是默认的镜像存放地址。
2.2 docker 的镜像都是tar 包?
是的,Docker的镜像实际上是以tar包的形式存储的。每个Docker镜像都由多个层(layers)组成,这些层以文件系统的形式存储在Docke 上。
每个镜像层都是一个只读的文件系统,它包含了文件和目录的快照。当你使用Docker构建镜像时,每一条指令都会创建一个新的镜像层。这种分层的结构使得镜像的构建和共享变得高效,因为多个镜像可以共享相同的层。
当你从Docker Hub或其他 拉取镜像时,实际上是将这些镜像层以tar包的形式下载到本地。这些tar包会被Docker存储在宿主机的文件系统中,供后续的容器创建和运行使用。
你可以使用docker save
命令将镜像保存为tar包,使用docker load
命令将tar包加载为镜像。这些命令可以让你在不同的Docker环境之间备份、迁移和共享镜像。
总结起来,Docker镜像实际上是由多个层组成的,以tar包的形式存储在宿主机上。这种分层结构和使用tar包的方式使得Docker镜像的构建、共享和管理变得更加灵活和高效。
2.3 Docker-compose 是直接使用镜像创建容器?
是的,Docker Compose是一个用于定义和运行多容器Docker应用程序的工具。使用Docker Compose,你可以使用一个单独的YAML文件来定义多个容器、它们之间的关联关系以及其他配置选项。然后,通过运行docker-compose up
命令,Docker Compose将根据定义的配置创建并启动所有的容器。
在Docker Compose配置文件中,你可以指定要使用的镜像名称、容器的名称、端口映射、环境变量、卷挂载等等。当你运行docker-compose up
命令时,Docker Compose会自动下载所需的镜像(如果本地不存在)并创建相应的容器。
下面是一个简单的Docker Compose配置文件示例,用于创建一个包含 PostgreSQL 和Redis两个容器的应用程序:
version: '3'
services:
db:
image: postgres
environment:
POSTGRES_PASSWORD: mysecretpassword
redis:
image: redis
在这个示例中,我们定义了两个服务(即容器):db
和redis
。db
服务使用了postgres
镜像,并设置了PostgreSQL的密码为mysecretpassword
。redis
服务使用了redis
镜像。
要运行这个配置文件,你可以在包含该文件的目录中打开终端或命令提示符,并运行以下命令:
docker-compose up
Docker Compose将会根据配置文件创建并启动db
和redis
两个容器。你可以通过docker-compose ps
命令来查看容器的状态。
总结来说,Docker Compose是通过配置文件来创建和管理多个容器的工具,它简化了多容器应用程序的部署和管理过程。
2.4 Docker Compose down 就是将容器删除?
是的,docker-compose down
命令用于停止并删除由Docker Compose启动的容器。当你运行docker-compose down
命令时,Docker Compose将会停止并删除在配置文件中定义的所有服务(容器),同时还会删除相关的网络和卷(如果有定义)。这个命令可以用来清理整个应用程序的运行环境。
需要注意的是,docker-compose down
命令会删除容器及其相关资源,包括数据卷中的数据。如果你希望保留数据,可以使用docker-compose stop
命令来停止容器,而不是使用docker-compose down
命令。
确保在运行docker-compose down
命令之前,你已经进入到包含docker-compose.yml
文件的目录,并且已经安装并正确配置了Docker Compose。
2.5 删除,会删除挂载嘛
是的,当你使用docker-compose down
命令删除容器时,它会删除与容器相关联的挂载卷(如果有定义)。挂载卷是将容器内的路径与宿主机上的路径进行关联,以便在容器重启或删除后保留数据。
如果你希望保留挂载卷中的数据,可以使用docker-compose down -v
命令。这个命令会在删除容器的同时,也删除挂载卷。如果你想要保留挂载卷中的数据,可以备份或迁移挂载卷的数据到其他位置,然后再运行docker-compose down -v
命令来删除容器和挂载卷。
需要注意的是,删除挂载卷会永久删除其中的数据,因此在执行删除操作之前,请确保备份了重要的数据。
yml 里面写了 volumes:
- /home/docker/nginx/data:/web/ 之后down 之后,宿主机里面的数据会删除嘛
如果你在docker-compose.yml
文件中使用了以下的挂载卷定义:
volumes:
- /home/docker/nginx/data:/web/
然后执行docker-compose down
命令来删除容器,那么默认情况下,这个挂载卷/home/docker/nginx/data
上的数据将会被保留在宿主机上。
docker-compose down
命令默认会删除容器实例,但不会删除挂载卷。只有在使用docker-compose down -v
命令时,才会删除与容器关联的挂载卷。
因此,如果你只执行了docker-compose down
命令,宿主机上的数据将会保留在/home/docker/nginx/data
目录中。如果你想要删除挂载卷以及宿主机上的数据,可以使用docker-compose down -v
命令。在执行删除操作之前,请确保备份了重要的数据。
2.6 DockerFile 和 docker compose 区别
Dockerfile 和 Docker Compose 是 Docker 中两个不同的概念和工具,它们用于不同的目的。
Dockerfile 是一个文本文件,用于定义和构建 Docker 镜像。它包含了一系列的指令,用于描述如何构建一个 Docker 镜像的步骤,包括基础镜像选择、安装软件包、复制文件、设置环境变量等。通过 Dockerfile,你可以自定义和管理你的镜像构建过程,以满足你的应用程序的需求。
Docker Compose 是一个工具,用于定义和管理多个 Docker 容器的应用程序。它使用一个 YAML 文件(通常称为 docker-compose.yml)来描述应用程序的不同服务、网络设置、卷挂载等配置。通过 Docker Compose,你可以定义一个多容器的应用程序,并使用一个命令来启动、停止、重启整个应用程序。它简化了多容器应用程序的部署和管理。
总结一下:
- Dockerfile 用于构建 Docker 镜像,描述了如何构建一个镜像的步骤。
- Docker Compose 用于定义和管理多个 Docker 容器的应用程序,描述了应用程序的不同服务和配置。
在实际使用中,你可以使用 Dockerfile 构建一个镜像,然后使用 Docker Compose 来定义和管理多个使用这个镜像的容器。这样可以方便地管理容器之间的关系、网络设置等,并实现整个应用程序的部署和管理。
3 部署nginx
将nginx 的 tar 包上传到服务器
输入docker images,发现目前是没有镜像的,现在将tar 包变成镜像
docker load -i nginx.tar
以上就将tar 包变成镜像了
因为需要容器里面目录和宿主机目录要一一挂载,容器卷,所以我们在宿主机上面创建要和容器一一对应的目录
以上是ngixn 的目录,以后修改这个宿主机目录下的东西,nginx 容器里面就会修改。 这个conf 目录文件夹下,有一个nginx 配置
这个就是ngixn 的配置文件,以后我们就是修改这个配置文件
因为我们要使用 Docker-compose 去管理容器,所以要使用Docker-compose 的东西;
需要找一个位置,专门放各个yml 文件
现在有一个关于nginx 的yml 编排文件,就是使用他去管理
里面内容是:
version: "2"
services:
nginx:
image: nginx
hostname: nginx
container_name: nginx
ports:
- "18080:8080"
- "18082:8081"
- "18088:8087"
volumes:
- /home/docker/nginx/data:/web/
- /home/docker/nginx/html:/usr/share/nginx/html
- /home/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
- /home/docker/nginx/logs:/var/log/nginx
- /home/metefont/hongt-data-center/hkdata:/HKONG/hkdata
- /home/metefont/mapdata:/home/metefont/mapdata
environment:
- TZ=Asia/Shanghai
这个文件是一个Docker Compose的配置文件,用于创建和管理一个Nginx容器。
解释每一行代码的意思:
version: "2"
这是Docker Compose配置文件的版本号。在这个示例中,使用的是版本号为2的配置文件格式。
version: "2"
services:
nginx:
image: nginx
hostname: nginx
container_name: nginx
ports:
- "18080:8080"
- "18082:8081"
- "18088:8087"
volumes:
- /home/softinstall/docker/nginx/data:/web/
- /home/softinstall/docker/nginx/html:/usr/share/nginx/html
- /home/softinstall/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
- /home/softinstall/docker/nginx/logs:/var/log/nginx
- /home/metefont/hongt-data-center/hkdata:/HKONG/hkdata
- /home/metefont/mapdata:/home/metefont/mapdata
environment:
- TZ=Asia/Shanghai
这部分定义了一个名为nginx
的服务(即Nginx容器)。以下是每个配置项的含义:
image: nginx
:指定使用的镜像为nginx
,这将从Docker Hub上下载Nginx镜像。hostname: nginx
:设置容器的主机名为nginx
。container_name: nginx
:指定容器的名称为nginx
。ports
:定义端口映射,将主机的端口与容器的端口进行绑定。在这个示例中,将主机的18080端口映射到容器的8080端口,将主机的18082端口映射到容器的8081端口,将主机的18088端口映射到容器的8087端口。volumes
:定义卷挂载,将主机的目录与容器的目录进行映射。在这个示例中,将主机的/home/docker/nginx/data
目录映射到容器的/web/
目录,将主机的/home/docker/nginx/html
目录映射到容器的/usr/share/nginx/html
目录,将主机的/home/docker/nginx/conf/nginx.conf
文件映射到容器的/etc/nginx/nginx.conf
文件,将主机的/home/docker/nginx/logs
目录映射到容器的/var/log/nginx
目录,将主机的/home/metefont/hongt-data-center/hkdata
目录映射到容器的/HKONG/hkdata
目录,将主机的/home/metefont/mapdata
目录映射到容器的/home/metefont/mapdata
目录。environment
:设置环境变量。在这个示例中,设置时区为Asia/Shanghai
。
这个配置文件的作用是创建一个名为nginx
的Nginx容器,并指定了端口映射、卷挂载和环境变量等配置。通过运行docker-compose up
命令,Docker Compose将会根据这个配置文件创建并启动该容器。
在这个nginx.yml 文件夹下,执行下面就启动了
docker-compose -f nginx.yml up -d
查看日志
docker logs -f nginx
确保nginx.conf 没问题,才可以启动成功
关闭容器
docker-compose -f nginx.yml down
如果第一次启动失败,要修改完配置文件之后,关闭之后重新启动
先执行
docker-compose -f nginx.yml down
后执行
docker-compose -f nginx.yml up -d
进入容器内部:
docker exec -it 容器id /bin/bash
放一个图片,浏览器访问