使用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 = 1sql_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: "2"
services:nginx:container_name: nginxhostname: nginxbuild:context: ./nginxdockerfile: Dockerfileports:- 80:80networks:vae:ipv4_address: 172.20.0.10volumes:- ./nginx/nginx.conf:/usr/local/nginx/nginx.conf- ./nginx/html:/usr/local/nginx/html#共享目录(将宿主机的目录挂载到容器)mysql:container_name: mysqlhostname: mysqlbuild:context: ./mysqldockerfile: Dockerfileports:- 3306:3306networks:vae:ipv4_address: 172.20.0.20volumes:- /usr/local/mysql#共享目录php:container_name: phphostname: phpbuild:context: ./phpdockerfile: Dockerfileports:- 9000:9000networks:vae:ipv4_address: 172.20.0.30volumes_from:#数据卷- nginx- mysqldepends_on:#依赖关系,php容器在nginx、mysql容器之后启动- nginx- mysql
networks:
#设置自定义网络vae:driver: bridgeipam: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 distributionCopyright (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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

云端部署Stirling PDF:构建个人App的API调用指南(附Python源码)

今天发现一个Github的开源项目&#xff0c;Stirling PDF&#xff0c;项目地址如下&#xff1a;https://gitcode.com/Stirling-Tools/Stirling-PDFhttps://gitcode.com/Stirling-Tools/Stirling-PDF?utm_sourceartical_gitcode目前CSDN上已经有好几个up主都介绍了这个项目&…

Python中类方法、静态方法和实例方法的使用场景

在Python中&#xff0c;类方法&#xff08;classmethod&#xff09;、静态方法&#xff08;staticmethod&#xff09;和实例方法是类的三种主要方法类型&#xff0c;它们各自适用于不同的场景&#xff1a; 实例方法 实例方法是最常用的方法类型&#xff0c;它用于操作实例属性…

环保设备统一管理系统

在环保意识日益增强的今天&#xff0c;企业如何有效管理环保设备&#xff0c;确保其正常运行&#xff0c;减少环境污染&#xff0c;成为了一个重要议题。HiWoo Cloud平台以其独特的环保设备统一管理系统&#xff0c;为企业提供了一套完整的解决方案&#xff0c;帮助企业实现绿色…

该怎么发外贸开发信才能瞄准大客户?

1.要知道80%的业务源自于大客户&#xff0c;要合理利用自己的时间。其实我自己发邮件一直都是粗发模式&#xff0c;效果也还可以&#xff0c;主要是因为我的客户都是展会上的&#xff0c;所以拒收和失败率会很低&#xff0c;而且客户意向度一直很高&#xff0c;但是花费的时间精…

Remix中使用 Tailwind

如何Remix 中使用 Tailwindcss Remix是通过 Vite 进行构建的&#xff0c;Vite 原生就支持 PostCSS&#xff0c;通过以下几步就可以设置完成 安装 PostCSS 插件 npm install -D tailwindcss autoprefixer添加PostCSS配置文件 ## postcss.config.js export default {plugins:…

SQL面试题每日一题之求解用户最长连续登录天数

SQL面试题每日一题之求解用户最长连续登录天数 之后会不定期更新每日一题sql系列。 SQL面试题每日一题系列内容均来自于网络以及实际使用情况收集&#xff0c;如与各大厂面试题有雷同&#xff0c;纯属巧合。 1.题目 问题&#xff1a;以下为多个用户每日登录记录数据&#x…

microsoft的azure语音,开发环境运行正常,发布到centos7线上服务器之后无法运行解决方案

最近在做AI语音对话的功能&#xff0c;用到了azure的语音语音服务&#xff0c;开发的时候还算顺利&#xff0c;部署到线上后&#xff0c;发现在正式服上无法完成语音转文本的操作&#xff0c;提示&#xff1a; org.springframework.web.util.NestedServletException: Handler …

浅谈Windows 上的线程亲和性(Thread affinity)

​ 前言 线程属性包括是否分离、亲和性、调度策略和优先级等。Linux默认的调度策略是CFS(完全公平调度算法),而 Windows 是基于优先级抢占式的策略。 在这些方面,Windows 和 Linux 差异巨大。本文仅针对 Windows 系统的线程亲和性进行探讨。 线程亲和性(Thread affinity) 什…

Softmax和Sigmoid

Softmax和Sigmoid函数在机器学习和深度学习中都扮演着重要的角色&#xff0c;但它们在功能和应用上存在一些关键的区别。 功能和应用领域&#xff1a; Softmax函数&#xff1a;主要用于多分类问题。它将一组实数&#xff08;通常是神经网络的输出&#xff09;转换为一组概率分…

手游广告归因新选择:Xinstall助力精准衡量投放效果

在手游市场竞争日益激烈的今天&#xff0c;广告主们面临着如何精准衡量广告投放效果的难题。手游广告归因平台的出现&#xff0c;为广告主们提供了一种全新的解决方案。而Xinstall&#xff0c;作为其中的佼佼者&#xff0c;正以其独特的优势&#xff0c;助力广告主们破解这一难…

​The Sandbox VoxEdit 迷你创作比赛|春天的资产

VoxEdit 迷你比赛 我们将为您带来一场新的 VoxEdit 迷你比赛&#xff01;在为期 8 天的比赛中&#xff0c;您将有机会快速创建并展示您的可用资产。 立即下载 VoxEdit 并开始参赛吧&#xff1a; The Sandbox - VoxEdit 比赛主题&#xff1a; 设计与春季环境相关的资产。本次比…

前端高频面试题 5.08

事件委托 事件委托是前端开发中常用的一种优化性能和代码可维护性的方法&#xff0c;它基于DOM的事件冒泡机制。当一个元素触发事件时&#xff0c;这个事件会按照从顶层到底层的顺序传播&#xff0c;直到最底层的元素&#xff08;通常是文档的根节点&#xff09;。事件委托利用…

第1章. STM32单片机入门知识介绍

目录 0. 《STM32单片机自学教程》专栏 1.1 嵌入式系统简介 1.1.1 什么是嵌入式系统 1.1.2 嵌入式系统的特点 1.1.3 嵌入式系统的应用领域 1.2 单片机基本概念 1.3 ARM简介 1.3.1 ARM公司简介 1.3.2 ARM处理器简介 1.4 STM32简介 1.4.1 基于Cortex内核的MCU 1.4.…

分红76.39亿,分红率再创新高,成长活力无限的伊利带来丰厚回报

伊利47万股东&#xff0c;又等来了一个好消息。 4月29日&#xff0c;伊利股份发布2023年报&#xff0c;实现营业总收入1261.79亿元&#xff0c;归母净利润104.29亿元&#xff0c;双创历史新高&#xff0c;实现连续31年稳健增长。 在递交亮眼成绩单的同时&#xff0c;乳业巨头伊…

头歌实践教学平台:CG3-v2.0-图形几何变换

第3关&#xff1a;图形的平移与旋转 一. 任务描述 1. 本关任务 (1) 理解几何变换基本原理, 掌握平移和旋转变换的方法; (2) 根据几何变换基本原理,将main函数中的空白部分补充完整。 2. 输入 (1) 代码将自动输入一个边长为2的obj正方体模型&#xff0c;具体模型如下图&…

DDR4 SDRAM 和LPDDR4的区别

DDR4 SDRAM(Double Data Rate Fourth Generation Synchronous Dynamic Random-Access Memory)和LPDDR4(Low Power Double Data Rate Fourth Generation)都是内存技术的标准,但它们设计用于不同的平台,并在性能、功耗和物理尺寸方面有所差异: 应用领域: DDR4 SDRAM 主要…

【力扣】746. 使用最小花费爬楼梯

原题链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 给你一个整数数组 cost &#xff0c;其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用&#xff0c;即可选择向上爬一个或者…

Unity图文混排EmojiText的使用方式和注意事项

​​​​​​​ 效果演示&#xff1a; 使用方式&#xff1a; 1、导入表情 2、设置图片格式 3、生成表情图集 4、创建/修改目标材质球 5、测试 修复换行问题 修复前&#xff1a; 修复后&#xff1a; 修复代码&#xff1a; 组件扩展 1、右键扩展 2、组件归类&#…

ODBC - 笔记

0 C++通过ODBC方式连接数据库SQLServer及增删查改操作【图书借阅系统为例】 C++通过ODBC方式连接数据库SQLServer及增删查改操作【图书借阅系统为例】_odbc5.2 c++怎么连接数据库-CSDN博客 0.1 c++使用libODBC linux - /lib/x86_64-linux-gnu/libodbc.so.2 win - /c/WINDO…

【MySQL数据库设计规范】安全规范

欢迎点开这篇文章&#xff0c;自我介绍一下哈&#xff0c;本人笔名姑苏老陈&#xff0c;是一个JAVA开发老兵。 本文收录于 《MySQL数据库设计规范》专栏中&#xff0c;该专栏主要分享一些关于MySQL数据库设计相关的技术规范文章&#xff0c;定期更新&#xff0c;欢迎关注&#…