使用docker-compose编排lnmp(dockerfile)完成wordpress

文章目录

    • 使用docker-compose编排lnmp(dockerfile)完成wordpress
      • 1、服务器环境
      • 2、Docker、Docker-Compose环境安装
        • 2.1 安装Docker环境
        • 2.2 安装Docker-Compose
      • 3、nginx
        • 3.1 新建目录,上传安装包
        • 3.2 编辑Dockerfile脚本
        • 3.3 准备nginx.conf配置文件
        • 3.4 论坛服务
      • 4、MySQL
        • 4.1 上传安装包
        • 4.2 编辑Dockerfile脚本
        • 4.3 准备my.cnf配置文件
      • 5、PHP
        • 5.1 上传安装包
        • 5.2 编辑dockerfile脚本
        • 5.3 准备php配置文件
      • 6、编辑docker-compose.yml配置文件
      • 7、生成镜像容器
      • 8、验证登录
      • 9、启动wordpress服务
        • 9.1 mysql授权
        • 9.2 访问登录

使用docker-compose编排lnmp(dockerfile)完成wordpress

1、服务器环境

容器操作系统IP地址主要软件
nginxCentOS 7.9 x86_64172.20.0.10Docker-Nginx
mysqlCentOS 7.9 x86_64172.20.0.20Docker-Mysql
phpCentOS 7.9 x86_64172.20.0.30Docker-php

2、Docker、Docker-Compose环境安装

[root@liuyanfen13 ~]#systemctl disable --now firewalld
[root@liuyanfen13 ~]#setenforce 0
#关闭防火墙和核心防护

image-20240503172627771

2.1 安装Docker环境
[root@liuyanfen13 ~]#yum install -y yum-utils device-mapper-persistent-data lvm2
#安装依赖包
[root@liuyanfen13 ~]#yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
#设置阿里云镜像源
[root@liuyanfen13 ~]#yum install -y docker-ce docker-ce-cli containerd.io
#安装Docker-CE(社区版)
[root@liuyanfen13 ~]#systemctl enable --now docker.service
#开机自启并立即启动
[root@liuyanfen13 ~]#systemctl status docker.service
#查看状态

image-20240503173103986

2.2 安装Docker-Compose
[root@liuyanfen13 compose_lnmp]#curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
#下载安装
[root@liuyanfen13 compose_lnmp]#chmod +x /usr/local/bin/docker-compose
#添加权限

image-20240503103606348

  • 需要的文件和安装包
[root@liuyanfen13 compose_lnmp]#pwd
/opt/compose_lnmp
[root@liuyanfen13 compose_lnmp]#ls
docker-compose.yml  mysql  nginx  php
[root@liuyanfen13 compose_lnmp]#cd mysql/
[root@liuyanfen13 mysql]#ls
Dockerfile  my.cnf  mysql-boost-5.7.20.tar.gz
[root@liuyanfen13 mysql]#cd ../nginx/
[root@liuyanfen13 nginx]#ls
Dockerfile  html  nginx-1.12.0.tar.gz  nginx.conf  wordpress-4.9.4-zh_CN.tar.gz
[root@liuyanfen13 nginx]#cd ../php/
[root@liuyanfen13 php]#ls
Dockerfile  php-7.1.10.tar.bz2  php-fpm.conf  php.ini  www.conf

image-20240503180151551

3、nginx

3.1 新建目录,上传安装包
[root@liuyanfen13 opt]#mkdir /opt/compose_lnmp
[root@liuyanfen13 opt]#cd compose_lnmp/
[root@liuyanfen13 compose_lnmp]#ll
总用量 0
[root@liuyanfen13 compose_lnmp]#mkdir nginx mysql php
[root@liuyanfen13 compose_lnmp]#ll
总用量 0
drwxr-xr-x. 2 root root 6 53 09:48 mysql
drwxr-xr-x. 2 root root 6 53 09:48 nginx
drwxr-xr-x. 2 root root 6 53 09:48 php

#上传nginx安装包nginx-1.12.0.tar.gz
#上传wordpress服务包wordpress-4.9.4-zh_CN.tar.gz
[root@liuyanfen13 nginx]#ls
nginx-1.12.0.tar.gz  nginx.conf  wordpress-4.9.4-zh_CN.tar.gz

image-20240503104826286

3.2 编辑Dockerfile脚本
#编辑dockerfile脚本
[root@liuyanfen13 nginx]#vim Dockerfile
FROM centos:7
MAINTAINER this is nginx image <lnmp>
RUN yum clean all
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.12.0.tar.gz /usr/local/src/
WORKDIR /usr/local/src/nginx-1.12.0
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make -j4 && make install
ENV PATH /usr/local/nginx/sbin:$PATH
ADD nginx.conf /usr/local/nginx/conf/
ADD wordpress-4.9.4-zh_CN.tar.gz /usr/local/nginx/html/
RUN chmod 777 -R /usr/local/nginx/html/
EXPOSE 80
EXPOSE 443
VOLUME ["/usr/local/nginx/html"]
ENTRYPOINT [ "/usr/local/nginx/sbin/nginx", "-g", "daemon off;" ]

image-20240503173528680

3.3 准备nginx.conf配置文件
[root@liuyanfen13 nginx]#egrep -v "^(.)*#(.)*$" nginx.conf | grep -v "^$"
#查看nginx.conf配置文件内容
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  localhost;
        charset utf-8;
        location / {
            root   html;
            index  index.html index.php;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        location ~ \.php$ {
            root           html;
            fastcgi_pass   172.20.0.30:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;
            include        fastcgi_params;
        }
    }
}

image-20240503173620351

3.4 论坛服务
[root@liuyanfen13 compose_lnmp]#cd nginx/
[root@liuyanfen13 nginx]#ls
Dockerfile  html  nginx-1.12.0.tar.gz  nginx.conf  wordpress-4.9.4-zh_CN.tar.gz
[root@liuyanfen13 nginx]#tar xf wordpress-4.9.4-zh_CN.tar.gz -C /opt/compose_lnmp/nginx/html/
#将wordpress解压到共享目录下
[root@liuyanfen13 nginx]#ll html/
总用量 8
-rw-r--r--. 1 root   root         5 53 16:44 index.html
drwxr-xr-x. 5 nobody nfsnobody 4096 28 2018 wordpress

image-20240503165435417

4、MySQL

4.1 上传安装包
[root@liuyanfen13 nginx]#cd ../mysql/
[root@liuyanfen13 mysql]#ls
[root@liuyanfen13 mysql]#ls
mysql-boost-5.7.20.tar.gz
#在mysql目录下上传mysql安装包

image-20240503105153583

4.2 编辑Dockerfile脚本
#编辑dockerfile脚本
[root@liuyanfen13 mysql]#vim Dockerfile
FROM centos:7
MAINTAINER this is mysql image <lnmp>
RUN yum clean all
RUN yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake make
ADD mysql-boost-5.7.20.tar.gz /usr/local/src/
WORKDIR /usr/local/src/mysql-5.7.20/
RUN cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8  \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1 && make -j4 && make install
ADD my.cnf /etc/
ENV PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH
RUN useradd -M -s /sbin/nologin  mysql
RUN chown mysql:mysql /etc/my.cnf
RUN chown -R mysql:mysql /usr/local/mysql/
RUN /usr/local/mysql/bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
VOLUME ["/usr/local/mysql"]
EXPOSE 3306
CMD ["/usr/local/mysql/bin/mysqld"]

image-20240503100824836

4.3 准备my.cnf配置文件
#编辑mysql配置文件
[root@liuyanfen13 mysql]#vim my.cnf
[client]
port = 3306
socket=/usr/local/mysql/mysql.sock

[mysql]
port = 3306
socket = /usr/local/mysql/mysql.sock
auto-rehash

[mysqld]
user = mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
port = 3306
character-set-server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
max_connections=2048
default-storage-engine=INNODB
max_allowed_packet=16M
server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

image-20240503101120752

5、PHP

5.1 上传安装包
[root@liuyanfen13 mysql]#cd ../php/
[root@liuyanfen13 php]#ls
[root@liuyanfen13 php]#ls
php-7.1.10.tar.bz2  php-fpm.conf  php.ini  www.conf
#在php目录下上传php安装包

image-20240503105322562

5.2 编辑dockerfile脚本
[root@liuyanfen13 php]#vim Dockerfile 
FROM centos:7
MAINTAINER this is php image <lnmp>
RUN yum install -y gd \
libjpeg libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel \
gcc gcc-c++ make pcre-devel;useradd -M -s /sbin/nologin nginx
ADD php-7.1.10.tar.bz2 /usr/local/src/
WORKDIR /usr/local/src/php-7.1.10
RUN ./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-mysqli \
--with-zlib \
--with-curl \
--with-gd \
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \
--with-openssl \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zip ; make -j4 ; make install
ENV PATH /usr/local/php/bin:/usr/local/php/sbin:$PATH
ADD php.ini     /usr/local/php/lib/
ADD php-fpm.conf /usr/local/php/etc/
ADD www.conf /usr/local/php/etc/php-fpm.d/
EXPOSE 9000
CMD /usr/local/php/sbin/php-fpm -F

image-20240503101513644

5.3 准备php配置文件
vim php.ini
date.timezone = Asia/Shanghai
#939行,取消注释,修改
mysqli.default_socket = /usr/local/mysql/mysql.sock
#1170行,修改

image-20240503101903819

#修改配置文件
vim php-fpm.conf 
pid = run/php-fpm.pid
#17行,删除注释符号“;”

#查看配置文件生效内容
[root@liuyanfen13 php]#egrep -v "^;" php-fpm.conf | egrep -v "^$"
[global]
pid = run/php-fpm.pid
include=/usr/local/php/etc/php-fpm.d/*.conf

image-20240503102059038

#修改配置文件
vim www.conf
user = nginx
group = nginx
#23、24行,修改用户和组
listen = 172.18.0.30:9000
#36行,修改监听IP和端口为容器IP:9000端口
listen.allowed_clients = 127.0.0.1,172.18.0.10
#62行,修改客户端地址

#查看配置文件生效的内容
[root@liuyanfen13 php]#egrep -v "^;" www.conf | egrep -v "^$"
[www]
user = nginx
group = nginx
listen = 172.20.0.30:9000
listen.allowed_clients = 127.0.0.1,172.20.0.10
pm = dynamic
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3

image-20240503174255390

6、编辑docker-compose.yml配置文件

#编辑docker-compose.yml配置文件
vim docker-compose.yml
version: "3"
services:
  nginx:
    container_name: nginx
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: Dockerfile
    ports:
      - 80:80
    networks:
      vae:
        ipv4_address: 172.20.0.10
    volumes:
      - ./nginx/nginx.conf:/usr/local/nginx/nginx.conf
      - ./nginx/html:/usr/local/nginx/html
      #共享目录(将宿主机的目录挂载到容器)
  mysql:
    container_name: mysql
    hostname: mysql
    build:
      context: ./mysql
      dockerfile: Dockerfile
    ports:
      - 3306:3306
    networks:
      vae:
        ipv4_address: 172.20.0.20
    volumes:
      - /usr/local/mysql
      #共享目录
  php:
    container_name: php
    hostname: php
    build:
      context: ./php
      dockerfile: Dockerfile
    ports:
      - 9000:9000
    networks:
      vae:
        ipv4_address: 172.20.0.30
    volumes_from:
    #数据卷
      - nginx
      - mysql
    depends_on:
    #依赖关系,php容器在nginx、mysql容器之后启动
      - nginx
      - mysql
networks:
#设置自定义网络
  vae:
    driver: bridge
    ipam:
      config:
        - subnet: 172.20.0.0/16

image-20240503174555943

image-20240503174933638

7、生成镜像容器

[root@liuyanfen13 compose_lnmp]#docker-compose -f docker-compose.yml up -d
#生成镜像容器
[root@liuyanfen13 compose_lnmp]#docker images
#显示所有镜像
[root@liuyanfen13 compose_lnmp]#docker ps -a
#显示所有容器

image-20240503175400408

image-20240503175510317

8、验证登录

http://192.168.10.13/wordpress/index.php
#浏览器访问验证

image-20240503170009506

9、启动wordpress服务

9.1 mysql授权
[root@liuyanfen13 nginx]#docker exec -it mysql bash
#进入mysql容器
[root@mysql mysql-5.7.20]# mysql -u root -p
#登录mysql
Enter password:
#初始密码为空,直接回车
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.20 Source distribution

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> create database wordpress;
Query OK, 1 row affected (0.00 sec)
#创建数据库
mysql> grant all privileges on wordpress.* to 'wordpress'@'%' identified by '123456';
Query OK, 0 rows affected, 1 warning (0.00 sec)
#授权
mysql> grant all privileges on *.* to 'root'@'%' identified by '123456';
Query OK, 0 rows affected, 1 warning (0.01 sec)
#授权
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
#刷新

image-20240503165714467

9.2 访问登录

image-20240503170147593

  • 修改wp-config.php配置文件

image-20240503170326431

[root@liuyanfen13 compose_lnmp]#docker exec -it nginx bash
#进入nginx容器
[root@nginx nginx-1.12.0]# cd /usr/local/nginx/html/
#切换到挂载目录
[root@nginx html]# cd wordpress/
[root@nginx wordpress]# ls
index.php    wp-activate.php     wp-comments-post.php  wp-cron.php        wp-load.php   wp-settings.php   xmlrpc.php
license.txt  wp-admin            wp-config-sample.php  wp-includes        wp-login.php  wp-signup.php
readme.html  wp-blog-header.php  wp-content            wp-links-opml.php  wp-mail.php   wp-trackback.php
[root@nginx wordpress]# cp wp-config-sample.php wp-config.php
[root@nginx wordpress]# vi wp-config.php
[root@nginx wordpress]# sed -n '23p;26p;29p;32p' wp-config.php
#显示修改的wordpress网站配置文件
define('DB_NAME', 'wordpress');
define('DB_USER', 'wordpress');
define('DB_PASSWORD', '123456');
define('DB_HOST', 'localhost');

image-20240503171850516

image-20240503171935199

image-20240503171356734

image-20240503171418470

image-20240503171454948
image-20240503171529014

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/592596.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

redis集群-主从机连接过程

首先从机需要发送自身携带的replid和offset向主机请求连接 replid&#xff1a;replid是所有主机在启动时会生成的一个固定标识&#xff0c;它表示当前复制流的id&#xff0c;当从机第一次请求连接时&#xff0c;主机会将自己的replid发送给从机&#xff0c;从机在接下来的请求…

docker部署nginx并配置https

1.准备SSL证书&#xff1a; 生成私钥&#xff1a;运行以下命令生成一个私钥文件。 生成证书请求&#xff08;CSR&#xff09;&#xff1a;运行以下命令生成证书请求文件。 生成自签名证书&#xff1a;使用以下命令生成自签名证书。 openssl genrsa -out example.com.key 2048 …

【Java探索之旅】内部类 静态、实例、局部、匿名内部类全面解析

文章目录 &#x1f4d1;前言一、内部类1.1 概念1.2 静态内部类1.3 实例内部类1.4 局部内部类1.5 匿名内部类 &#x1f324;️全篇总结 &#x1f4d1;前言 在Java编程中&#xff0c;内部类是一种强大的特性&#xff0c;允许在一个类的内部定义另一个类&#xff0c;从而实现更好的…

Vue3-element-plus表格

一、element-plus 1.用组件属性实现跳转路由 <el-menu active-text-color"#ffd04b" background-color"#232323" :default-active"$route.path" //高亮 text-color"#fff"router><el-menu-item index"/article/channe…

第十篇:深入文件夹:Python中的文件管理和自动化技术

深入文件夹&#xff1a;Python中的文件管理和自动化技术 1 文件系统基础操作 在今天的技术博客中&#xff0c;我们将深入探讨Python中的文件系统基础操作。文件系统对于任何操作系统都是不可或缺的组成部分&#xff0c;它管理着数据的存储、检索以及维护。Python通过其标准库中…

节能洗车房车牌识别项目实战

项目背景 学电子信息的你加入了一家节能环保企业&#xff0c;公司的主营产品是节能型洗车房。由于节水节电而且可自动洗车&#xff0c;产品迅速得到了市场和资本的认可。公司决定继续投入研发新一代产品&#xff1a;在节能洗车房的基础上实现无人值守的功能。新产品需要通过图…

Java高阶私房菜:JVM性能优化案例及讲解

目录 核心思想 优化思考方向 压测环境准备 堆大小配置调优 调优前 调优后 分析结论 垃圾收集器配置调优 调优前 调优后 分析结论 JVM性能优化是一项复杂且耗时的工作&#xff0c;该环节没办法一蹴而就&#xff0c;它需要耐心雕琢&#xff0c;逐步优化至理想状态。“…

Qt服务器端与客户端交互

Qt做客户端与服务器端交互第一步引入network 第一步引入network后继续编程首先界面设计 创建server和socket 引入QTcpServer&#xff0c;QTcpSocket MainWindow.h代码如下 #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QTcpServer&…

EPAI手绘建模APP演示板、材质编辑器、样式编辑器

(11) 更多 图 74 更多工具栏 ① 演示板&#xff1a;打开关闭演示板。演示板用来显示从设备导入的模型图纸图片或者打开模型建模教程网页&#xff0c;是建模过程中一个辅助功能。有些设备有小窗口功能有些没有&#xff0c;对于没有小窗口功能的设备&#xff0c;通过演示板能够在…

智慧旅游引领旅游行业创新发展:借助智能科技的力量,实现旅游资源的优化配置和高效利用,推动旅游行业的转型升级和可持续发展

目录 一、引言 二、智慧旅游的定义与特点 1、信息化程度高 2、智能化服务丰富 3、互动性强 4、个性化服务突出 5、可持续性发展 三、智慧旅游在旅游行业创新发展中的作用 &#xff08;一&#xff09;优化旅游资源配置 &#xff08;二&#xff09;提升旅游服务质量 &…

【吃透Java手写】- Spring(上)-启动-扫描-依赖注入-初始化-后置处理器

【吃透Java手写】Spring&#xff08;上&#xff09;启动-扫描-依赖注入-初始化-后置处理器 1 准备工作1.1 创建自己的Spring容器类1.2 创建自己的配置类 ComponentScan1.3 ComponentScan1.3.1 Retention1.3.2 Target 1.4 用户类UserService Component1.5 Component1.6 测试类 2…

HCIA-题目解析1

0x00 前言 遇到这样一道题,这种题目对于我来说还是比较复杂的,所以记录一下。主要还是和熟练度有关系。 0x01 题目 路由器RouterID邻居关系如下,下列说法正确的是 A:本路由器和Router-lD为10.0.3.3的路由器不能直接交换链路状态信息 B:DR路由器的Router-lD为10.0.1.2 C:…

机器学习:基于K-近邻(KNN)、高斯贝叶斯(GaussianNB)、SVC、随机森林(RF)、梯度提升树(GBDT)对葡萄酒质量进行预测

前言 系列专栏&#xff1a;机器学习&#xff1a;高级应用与实践【项目实战100】【2024】✨︎ 在本专栏中不仅包含一些适合初学者的最新机器学习项目&#xff0c;每个项目都处理一组不同的问题&#xff0c;包括监督和无监督学习、分类、回归和聚类&#xff0c;而且涉及创建深度学…

Finder Windows for Mac:双系统窗口,一键切换!

Finder Windows for Mac是一款专为Mac用户设计的实用工具&#xff0c;它模拟了Windows系统的窗口管理功能&#xff0c;让Mac用户也能享受到类似Windows的窗口操作体验。这款软件的主要功能是提供一个浮动面板&#xff0c;帮助用户随时即时访问打开的Finder窗口列表&#xff0c;…

力扣每日一题106:从中序与后序遍历序列构造二叉树

题目 中等 相关标签 相关企业 给定两个整数数组 inorder 和 postorder &#xff0c;其中 inorder 是二叉树的中序遍历&#xff0c; postorder 是同一棵树的后序遍历&#xff0c;请你构造并返回这颗 二叉树 。 示例 1: 输入&#xff1a;inorder [9,3,15,20,7], postorder …

在线协作,开源的设计和原型创作平台:penpot

penpot&#xff1a;面向团队&#xff0c;设计自由- 精选真开源&#xff0c;释放新价值。 概览 Penpot 是一款专为跨职能团队量身定制的开源设计软件&#xff0c;与行业领先的 Figma 齐名&#xff0c;提供了一个强大而灵活的在线设计解决方案。其最大的亮点在于&#xff0c;用户…

Qt与MySQL连接

QT连接Mysql数据库&#xff08;详细成功版&#xff09;-CSD N博客 我的MySQL是64位的&#xff0c;所以我的Qt的套件也需要是64位的 遇到的问题&#xff1a; &#xff08;available drivers中已经有QMYSQL QMYSQL3&#xff0c;还是not loaded&#xff09; QSqlDatabase: QMYS…

SQL注入-基础知识

目录 前言 一&#xff0c;SQL注入是什么 二&#xff0c;SQL注入产生的条件 三&#xff0c;学习环境介绍 四、SQL注入原理 五&#xff0c;SQL中常用的函数 六&#xff0c;关于Mysql数据库 前言 在网络安全领域中&#xff0c;sql注入是一个无法被忽视的关键点&#xff0c…

安卓 app icon大小 安卓app界面尺寸大小

移动应用的界面设计画布尺寸设计多大&#xff08;特别是Android&#xff09;、图标和字体大小怎么定、需要设计多套设计稿么、如何切图以配合开发的实现&#xff1f; 本篇将结合iOS和android官方的设计规范、搜集的资料以及工作中的摸索&#xff0c;来分享移动应用界面设计中的…

【C++】STL — List的接口讲解 +详细模拟实现

前言&#xff1a; 本章我们将学习STL中另一个重要的类模板list… list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代。list的底层是带头双向循环链表结构&#xff0c;双向链表中每个元素存储在互不相关的独立节点中&#xf…