(第四十天)配置完整的考试系统,完成前端和后端并优化,mysql后端,nginx前端,java连接

本文主要是介绍(第四十天)配置完整的考试系统,完成前端和后端并优化,mysql后端,nginx前端,java连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

回顾
1 、使用 harbor 仓库
python --version
yum -y update
yum -y install python2-pip
pip install --upgrade pip == 20 .3 -i .......
pip install docker-compose -i .......
sh docker.sh
解压 harbor
vim harbor.yml
./prepare
./installed
使用 nginx 发布 web 服务
使用 registry 管理
2 docker-compose 的编排
在学习 kubernetes 之前的热身
通过运行一个 yum 管理 docker 容器
docker-compose.yml
vim docker-compose.yml
version: "3"
services:
nginx:
contanner_name: name0
image: nginx:latest
ports:
- "80:80"
volums:
- /opt/web/:/usr/share/nginx/html/
一、项目 - 使用 docker 部署 project-exam-system
1 、背景
在一台主机之内,实现容器的编排,发布考试系统
2 、环境准备
# 部署 docker 环境
[root@docker ~] # sh docker.sh
[root@docker ~] # vim /etc/docker/daemon.json
{
"registry-mirrors" : [
"https://do.nark.eu.org" ,
"https://dc.j8.work" ,
"https://docker.m.daocloud.io" ,
"https://dockerproxy.com" ,
"https://docker.mirrors.ustc.edu.cn" ,
"https://docker.nju.edu.cn"
],
"host" : [
"tcp://0.0.0.0:2375" ,
"unix:///var/run/docker.sock"
],
"insecure-registries" : [
"http://10.0.0.7:5000"
]
}
[root@docker ~] # vim /usr/lib/systemd/system/docker.service
ExecStart = /usr/bin/dockerd
[root@docker ~] # systemctl daemon-reload
[root@docker ~] # systemctl start docker
[root@docker ~] # docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
3 、前端配置
前端使用 nginx 服务
1 )测试:容器搭建 nginx 服务
# 拉取 nginx 镜像
[root@docker ~] # docker pull nginx
[root@docker ~] # docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest 5ef79149e0ec 2 weeks ago 188MB
# 创建一个容器测试一下 nginx 服务
[root@docker ~] # docker run -itd -p80:80 nginx:latest
fc8a6e06f77d877c8341c8a5aed3ec50fa448918bc672b2e330db8060b947a57
[root@docker ~] # docker ps -a
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
fc8a6e06f77d nginx:latest "/docker-entrypoint.…" 10 seconds ago Up 9
seconds 0 .0.0.0:80->80/tcp, :::80->80/tcp busy_mccarthy
[root@docker ~] # docker exec -it fc8a ls /usr/share/nginx/html
50x.html index.html
# 在容器启动后, nginx 服务就自动发布了
[root@docker ~] # curl localhost
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>
<p>For online documentation and support please refer to
<a href = "http://nginx.org/" >nginx.org</a>.<br/>
Commercial support is available at
<a href = "http://nginx.com/" >nginx.com</a>.</p>
<p><em>Thank you for using nginx.</em></p>
</body>
</html>
# 主机浏览器访问
2 )上传前端项目映射到容器中
# 上传前端项目 dist
# 创建一个目录,不单独放置前端的资料,将后端的所有资料也都放在这里
[root@docker ~] # mkdir project_exam_system
[root@docker ~] # cd project_exam_system/
[root@docker project_exam_system] # mkdir web
[root@docker ~] # unzip project_exam_system.zip
[root@docker ~] # mv dist project_exam_system/web/
[root@docker ~] # cd project_exam_system
[root@docker project_exam_system] # ls
web
[root@docker project_exam_system] # cd web/
[root@docker web] # ls
dist
# 将测试容器删除
[root@docker web] # docker rm -f fc8
fc8
# 再创建容器,映射端口,挂载目录
[root@docker project_exam_system] # docker run -itd -p80:80 -v
/root/project_exam_system/web/dist/:/usr/share/nginx/html/ nginx:latest
98646a277c8bd126a3fd39453707b5ab66a8869be963e3680653610c991e46af
[root@docker project_exam_system] # docker ps
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
98646a277c8b nginx:latest "/docker-entrypoint.…" 9 seconds ago Up 9
seconds 0 .0.0.0:80->80/tcp, :::80->80/tcp unruffled_gauss
3 )结果展示
出现问题,在实现登录时,出现后端异常,原因是后端还没有配置。
从上面图片可以看出来,请求的域名为 bu.yuanyu.zhangmin ,现在我们需要将域名劫持下来,将该域名指向我们的linux 主机,在 linux 主机中使用容器搭建后端服务器,所以要在本机的 hosts 文件中写入域名的对应关系,使其指向linux 主机
配置完成后,本机能够 ping bu.yuanyu.zhangmin 域名并由 10.0.0.7 主机回应即配置成功
4 、后端配置
后端的业务 springboot
优点:不用单独部署 tomcat ,已经在 springboot 中内置 tomcat
1 )测试:在 centos 容器中配置 java 环境,修改数据库地址并运行 war
# 拉取基础 centos 镜像
[root@docker ~] # docker pull centos
# 创建 centos 容器
[root@docker ~] # docker run -it centos:latest /bin/bash
[root@d34e6c6d34d7 /] # ls
bin etc lib lost + found mnt proc run srv tmp var
dev home lib64 media opt root sbin sys usr
[root@d34e6c6d34d7 /] # [root@docker ~]#
# 试图使用 scp 将服务器上的 war 包上传给容器中去,发现上传不了
[root@docker ~] # scp Project_ExamSystem-V1.0.0.war root@172.17.0.3:~
ssh : connect to host 172 .17.0.3 port 22 : Connection refused
lost connection
# 查看 docker 帮助文档
[root@docker ~] # docker --help
cp Copy files/folders between a container and the local filesystem
# 查看 docker cp 帮助文档
[root@docker ~] # docker cp --help
Usage: docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|-
docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH
[root@docker ~] # docker ps
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
d34e6c6d34d7 centos:latest "/bin/bash" 3 minutes ago Up
3 minutes gifted_brown
98646a277c8b nginx:latest "/docker-entrypoint.…" 31 minutes ago Up
31 minutes 0 .0.0.0:80->80/tcp, :::80->80/tcp unruffled_gauss
# 使用 cp 命令将服务器中的 war 包、 jdk 包、 application.properties 文件上传到容器中
# 需要 jdk17 版本
[root@docker ~] # docker cp Project_ExamSystem-V1.0.0.war d34e:/
Successfully copied 41MB to d34e:/
[root@docker ~] # docker cp jdk-17_linux-x64_bin.tar.gz d34e:/
Successfully copied 183MB to d34e:/
[root@docker ~] # docker cp application.properties d34e:/
Successfully copied 4 .1kB to d34e:/
# 进入到容器中
# 对已经传到容器的文件进行部署
[root@docker ~] # docker attach d34e
# 查看,是否上传成功
[root@d34e6c6d34d7 /] # ls
Project_ExamSystem-V1.0.0.war dev jdk-17_linux-x64_bin.tar.gz lost + found
opt run sys var
application.properties etc lib media proc sbin
tmp
bin home lib64 mnt root srv usr
# 创建 jdk 目录
[root@d34e6c6d34d7 /] # mkdir /usr/local/jdk
# jdk 包解压到 jdk 目录下
[root@d34e6c6d34d7 /] # tar -zxf jdk-17_linux-x64_bin.tar.gz -C
/usr/local/jdk/ --strip-components=1
# 查看解压是否成功
[root@d34e6c6d34d7 /] # ls /usr/local/jdk/
LICENSE README bin conf include jmods legal lib man release
# 修改 application.properties 文件内容,指定数据库位置
[root@d34e6c6d34d7 /] # vi application.properties
spring.datasource .url = jdbc:mysql://10.0.0.7:3306/project_exam_system
# 使用 java 命令运行 war
[root@d34e6c6d34d7 /] # /usr/local/jdk/bin/java -jar Project_ExamSystem
V1.0.0.war
: Started ProjectExamSystemApplication in 16 .425 seconds (process
running for 18 .114)
# ctrl p q 退出容器
read escape sequence
# 测试 war 包是否正常运行
# 以下显示表示正常
[root@docker ~] # curl 172.17.0.3:8080
{ "code" :20002, "msg" : " 账号不存在或密码错误 " }[root@docker ~] #
2 )将 centos 容器封装为 java 镜像并创建 java 容器
# 查看 commit 帮助文档
[root@docker ~] # docker commit --help
Usage: docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
# 根据容器创建镜像
[root@docker ~] # docker commit d34 java:v0
sha256:1d715d202236751037fc5f67084c2e437e4aeb3159f5a9e74017d8f555e1767d
[root@docker ~] # docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
java v0 1d715d202236 31 seconds ago 774MB
nginx latest 5ef79149e0ec 2 weeks ago 188MB
centos latest 5d0da3dc9764 2 years ago 231MB
# 停止 centos 容器
[root@docker ~] # docker stop d34
d34
# 移除 centos 容器
[root@docker ~] # docker rm d34
d34
# 根据新建的镜像,创建容器
[root@docker ~] # docker run -itd -p8080:8080 java:v0 /usr/local/jdk/bin/java
-jar Project_ExamSystem-V1.0.0.war
9337c1beb386d63b6c9ddc3bf25c1830af16505e6e29844a4599a10b2888f16c
# 查看容器的进程
[root@docker ~] # docker ps
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
9337c1beb386 java:v0 "/usr/local/jdk/bin/…" 4 seconds ago Up
3 seconds 0 .0.0.0:8080->8080/tcp, :::8080->8080/tcp boring_einstein
98646a277c8b nginx:latest "/docker-entrypoint.…" About an hour ago Up
About an hour 0 .0.0.0:80->80/tcp, :::80->80/tcp unruffled_gauss
3 )结果展示
浏览器访问,出现 500 错误,说明 java 项目部署不对,主要是数据库未导入数据。
5 、数据持久化业务 mysql-5.7.44
1 )配置 mysql 容器并导入 sql 数据
# 拉取 mysql:5.7.44
[root@docker ~] # docker pull mysql:5.7.44
[root@docker ~] # docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
java v0 1d715d202236 3 hours ago 774MB
nginx latest 5ef79149e0ec 2 weeks ago 188MB
mysql 5 .7.44 5107333e08a8 8 months ago 501MB
centos latest 5d0da3dc9764 2 years ago 231MB
# 创建 mysql 容器
[root@docker ~] # docker run -itd -e MYSQL_ROOT_PASSWORD=root -p3306:3306
mysql:5.7.44
9f30dfb770753a5b50872f29d961da87e41e7dcdfcd3e9e187193a8384cd2990
[root@docker ~] # docker ps
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
9f30dfb77075 mysql:5.7.44 "docker-entrypoint.s…" 13 seconds ago Up 11
seconds 0 .0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060 /tcp
heuristic_varahamihira
9337c1beb386 java:v0 "/usr/local/jdk/bin/…" 3 hours ago Up 3
hours 0 .0.0.0:8080->8080/tcp, :::8080->8080/tcp
boring_einstein
98646a277c8b nginx:latest "/docker-entrypoint.…" 4 hours ago Up 4
hours 0 .0.0.0:80->80/tcp, :::80->80/tcp
unruffled_gauss
# 创建 mysql 目录
[root@docker ~] # mkdir mysql
# sql 文件移动到 mysql 目录下
[root@docker ~] # mv project_exam_system.sql project_exam_system/mysql/
# 使用 Navicat Premium 应用软件将 sql 文件中的数据导入到数据库中
2 )进入数据库中创建指定用户并为用户授权
# 进入数据库中查看数据
[root@docker project_exam_system] # docker exec -it 9f30 mysql -uroot -proot
mysql> show databases;
+ --------------------- +
| Database |
+ --------------------- +
| information_schema |
| mysql |
| performance_schema |
| project_exam_system |
| sys |
+ --------------------- +
5 rows in set (0.01 sec)
mysql> use project_exam_system
mysql> show tables;
+ ------------------------------- +
| Tables_in_project_exam_system |
+ ------------------------------- +
| admin |
| category |
| com_city |
| com_nation |
| course |
| dept |
| dept_student |
| exam |
| exam_dept |
| exam_process |
| loginlog |
| major |
| menu |
| paper |
| paper_topic |
| role |
| role_admin |
| role_menu |
| semester |
| student |
| teacher |
| topic |
| user |
+ ------------------------------- +
23 rows in set (0.00 sec)
mysql> select * from user;
+ ----- + -------------- + ---------- + -------- + --------------------- + ---------- + --
------------------- + -------- + ------- +
| id | userName | password | status | createTime | createOr |
editTime | editOr | isDel |
+ ----- + -------------- + ---------- + -------- + --------------------- + ---------- + --
------------------- + -------- + ------- +
| 1 | 21001189 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-22 22 :04:44 | NULL | 0 |
| 2 | 21001190 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 3 | 21001191 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 4 | 21001192 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 5 | 21001193 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 6 | 21001194 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 7 | 21001195 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 8 | 21001196 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 9 | 21001197 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
| 10 | 21001198 | 111111 | 0 | 2024 -08-21 09 :45:05 | NULL |
2024 -08-21 09 :45:05 | NULL | 0 |
# 由于连接数据库使用的用户是 zhangsan ,所以我们需要创建 zhangsan 用户并授权
mysql> create user 'zhangmin' @ '%' identified by 'zhangmin' ;
Query OK, 0 rows affected (0.09 sec)
mysql> grant all on *.* to 'zhangmin' @ '%' ;
Query OK, 0 rows affected (0.02 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.04 sec)
3 )结果展示
6 、优化(使用 Dockerfile 直接制作 java 镜像)
1 )创建 java 目录,将所需文件移动到 java 目录下
[root@docker ~] # mkdir project_exam_system/java
[root@docker ~] # mv jdk-17_linux-x64_bin.tar.gz project_exam_system/java/
[root@docker ~] # mv application.properties project_exam_system/java/
[root@docker ~] # mv Project_ExamSystem-V1.0.0.war project_exam_system/java/
[root@docker ~] # cd project_exam_system/java/
[root@docker java] # tar -zxf jdk-17_linux-x64_bin.tar.gz
[root@docker java] # mv jdk-17.0.12/ jdk
# 修改连接后端数据库的 IP 地址
[root@docker java] # vim application.properties
spring.datasource .url = jdbc:mysql://10.0.0.7:3306/project_exam_system
2 )在 java 目录下编辑 Dockerfile 文件
[root@docker java] # vim Dockerfile
FROM centos:latest
ADD application.properties /application.properties
ADD Project_ExamSystem-V1.0.0.war /Project_ExamSystem-V1.0.0.war
ADD jdk /usr/local/jdk
WORKDIR /
EXPOSE 8080
CMD [ "/usr/local/jdk/bin/java" , "-jar" , "Project_ExamSystem-V1.0.0.war" ]
3 )使用 Dockerfile 文件创建 java 镜像并创建一个 java 容器测试
[root@docker java] # docker build -t java:v2 .
[ + ] Building 3 .1s (11/11) FINISHED
# 发现 java:v2 java:v1 小很多,由于使用的是 centos 镜像为基础镜像是关闭状态一层一层封装为
java 镜像的
[root@docker java] # docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
java v2 d06359c88e57 23 minutes ago 591MB
java v0 1d715d202236 6 hours ago 774MB
nginx latest 5ef79149e0ec 2 weeks ago 188MB
mysql 5 .7.44 5107333e08a8 8 months ago 501MB
centos latest 5d0da3dc9764 2 years ago 231MB
[root@docker java] # docker run -itd -p8081:8080 java:v2
3bebbb51648947c5893e27da41540fab92d956812bf8def0595c46881dd54e72
[root@docker java] # docker ps -a
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
3bebbb516489 java:v2 "/bin/bash /java.sh" 10 seconds ago Up 8
seconds 0 .0.0.0:8081->8080/tcp, :::8081->8080/tcp
nervous_zhukovsky
9f30dfb77075 mysql:5.7.44 "docker-entrypoint.s…" 2 hours ago Up 2
hours 0 .0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060 /tcp
heuristic_varahamihira
9337c1beb386 java:v0 "/usr/local/jdk/bin/…" 5 hours ago Up 5
hours 0 .0.0.0:8080->8080/tcp, :::8080->8080/tcp
boring_einstein
98646a277c8b nginx:latest "/docker-entrypoint.…" 6 hours ago Up 6
hours 0 .0.0.0:80->80/tcp, :::80->80/tcp
unruffled_gauss
[root@docker java] # curl 10.0.0.7:8081
{ "code" :20002, "msg" : " 账号不存在或密码错误 " }[root@docker java] #
[root@docker java] # docker exec -it 3b ss -tupln | grep 8080
tcp LISTEN 0 128 *:8080 *:* users:
(( "java" ,pid = 7 ,fd = 9 ))
4 )使用 Dockerfile 文件创建 nginx 镜像
[root@docker web] # ls
dist Dockerfile
[root@docker web] # vim Dockerfile
FROM nginx:latest
ADD dist/ /usr/share/nginx/html/
EXPOSE 80
CMD [ "nginx" , "-g" , "daemon off;" ]
[root@docker web] # docker run -itd --name n0 -p80:80 nginx:v1
5 )使用 Dockerfile 文件创建 mysql 镜像
[root@docker mysql] # ls
Dockerfile project_exam_system.sql
[root@docker mysql] # vim project_exam_system.sql
最后加入
CREATE USER 'zhangmin' @ '%' IDENTIFIED BY 'zhangmin' ;
GRANT ALL PRIVILEGES ON *.* TO 'zhangmin' @ '%' WITH GRANT OPTION;
flush privileges;
[root@docker mysql] # vim Dockerfile
FROM mysql:5.7.44
ENV MYSQL_ROOT_PASSWORD = root
ADD project_exam_system.sql /docker-entrypoint-initdb.d/
EXPOSE 3306
[root@docker mysql] # docker run -itd --name m0 -p3306:3306 mysql:v1

这篇关于(第四十天)配置完整的考试系统,完成前端和后端并优化,mysql后端,nginx前端,java连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132828

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示