部署Discuz论坛项目

DIscuz 是由 PHP 语言开发的一款开源社交论坛项目。运行在典型的LNMP/LAMP 环境中。

安装MySQL数据库5.7
主机名IP地址操作系统硬件配置
discuz-db192.168.226.128CentOS 7-mini-20092 Core/4G Memory

修改主机名用来自己识别

hostnamectl set-hostname discuz-db
#重连远程更新或使用bash命令启动一个新的交互式的命令行界面

下载 MySQL 仓库

rpm -ivh https://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

导入 GPG 密钥文件

rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022

安装 MySQL 软件包

yum install mysql-server -y

启动 MySQL 程序

systemctl enable mysqld --now

查看 MySQLroot 初始密码

grep -i password /var/log/mysqld.log

通过初始密码登录到数据库

 mysql -uroot -p'密码'

修改密码复杂度策略(即不验证复杂度)

mysql> SET GLOBAL validate_password_policy=LOW;

修改密码长度(用来短位数密码方便学习使用)

mysql> SET GLOBAL validate_password_length=4;

设置 root 本机登录密码(长度须满足8位)

mysql> alter user root@"localhost" identified by "1234";

退出数据库

mysql> exit

修改 /etc/my.cnf 文件,在文件中定义密码策略,让策略永久生效

vim /etc/my.cnf#最后一行新增如下代码
validate_password_policy=0
#设置字符集支持中文
character-set-server=utf8

重启 MySQL 使配置生效

systemctl restart mysqld

登录数据库授权 root 账号可以远程登录,后边需要测试 PHP 与数据库的连接

mysql -uroot -p1234
#创建一个root用户用来远程访问用,这个root和登录本机登录数据库的root不是同一个哈,现在创建成功后数据库就有两个root用户拉。
mysql> CREATE USER 'root'@'%' IDENTIFIED BY 'admin123456';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'admin123456';
mysql> FLUSH PRIVILEGES;

创建对应的 discuz

mysql> create database discuz;

退出数据库

mysql> exit
安装Nginx web服务
主机名IP地址操作系统硬件配置
discuz01192.168.226.129CentOS 72 Core/4G Memory
discuz02192.168.226.130CentOS 72 Core/4G Memory

Nginx版本分为 Mainline (开发版本)、Stable (最新稳定版)和Legacy (旧的稳定版)。

修改主机名(记得初始化脚本对虚拟机初始设置)

#对192.168.226.129操作
hostnamectl set-hostname discuz01
#对192.168.226.130操作
hostnamectl set-hostname discuz02

准备 Nginx 稳定版仓库,仓库地址:https://nginx.org/en/linux_packages.html#RHEL

提示:在 discuz01discuz02 主机安装

vim /etc/yum.repos.d/nginx.repo[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

安装 Nginx 软件包

yum install nginx-1.20.2 -y

Nginx常用相关文件

/etc/nginx/nginx.conf #Nginx主配置文件

/usr/share/nginx/html #Nginx网页目录

/var/log/nginx/error.log #Nginx错误日志文件

/var/log/nginx/access.log #Nginx访问日志文件

/etc/nginx/conf.d/ #虚拟web主机目录

安装PHP相关软件

php #是php代码的解释器
php-fpm #管理php进程接收请求
php-mysql #与MySQL集成,连接MySQL数据库并进行增删改查
php-gd #帮助php处理图片的扩展,如生成图片、裁剪图片、缩放图片等

提示:在 discuz01discuz02 主机安装

yum install php php-fpm php-mysql php-gd -y

修改配置文件:/etc/php-fpm.d/www.conf,指定PHP程序运行时的用户与组,并开启PHP状态页面用于监控服务状态。

vim /etc/php-fpm.d/www.conf 
#...#指定PHP程序运行时的用户和组为Nginx
#在第39行
user = nginx
#在第41行
group = nginx#在第121行,取消 ;号注释,开启PHP状态页面,并改名为/php_status
pm.status_path = /php_status

修改配置文件指定php时区:/etc/php.ini

vim /etc/php.ini +878
#...#在第878行取消注释,并修改PHP时区
date.timezone ="Asia/shanghai"

修改 Nginx 虚拟web主机配置文件,定义网站信息:/etc/nginx/conf.d/

#清空该路径默认文件
rm -rf /etc/nginx/conf.d/*
vim /etc/nginx/conf.d/discuz.confserver {listen       80;server_name  localhost;#开启nginx状态页面location = /status {    stub_status;}location / {root   /usr/share/nginx/html;index  index.php index.html index.htm;  }#配置nginx连接phplocation ~ \.php$ {root           /usr/share/nginx/html; fastcgi_pass   127.0.0.1:9000;fastcgi_index  index.php;fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;include        fastcgi_params;}#开启php页面location /php_status {root           html;fastcgi_pass   127.0.0.1:9000;fastcgi_index  index.php;fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;include        fastcgi_params;}
}

启动 NginxPHP

systemctl start nginx php-fpm
systemctl enable nginx php-fpm

测试 NginxPHP 之间的连接

vim /usr/share/nginx/html/phpinfo.php<?php
phpinfo();
?>

重启Nginx和PHP

systemctl restart nginx php-fpm

访问页面测试(你需要改成你的IP):访问正确页面则会显示php默认页面

http://192.168.226.129/phpinfo.php

http://192.168.226.130/phpinfo.php

测试 PHPMySQL 之间的连接

vim /usr/share/nginx/html/mysql.php 
#这里面的ip要修改成你配数据库的虚拟机的ip,root密码就是添加的一个root用户的admin123456的密码
#在数据库哪里新增创建拉一个root专门用来远程访问的,这里迷惑拉去看数据库那
<?php
$con=mysql_connect("192.168.226.128","root","admin123456");
if(!$con){die("could not connect to the db:\n".mysql_error());
}
else{echo "success";
}
mysql_close($con);
?>

访问页面测试:正确页面会显示 success

http://192.168.226.129/mysql.php

http://192.168.226.130/mysql.php

上线Discuz论坛项目

discuz01 主机切换到Nginx网页目录并删除自带的页面文件

cd /usr/share/nginx/html/
rm -rf *

自行将项目源码包上传

下载解压工具

yum -y install zip unzip

解压项目到网页目录

unzip Discuz_X3.3_SC_UTF8.zip 

upload 下的页面文件移动到至当前 html 目录

mv upload/* .

修改项目文件权限,确保 Nginx 用户对所有项目文件具备完全权限

chown -R nginx.nginx .

访问Discuz:

http://192.168.226.129/

http://192.168.226.130/

两个ip都能看到如下页面就表示成功

如下页面安装只针对一台机器操作,这里我对discuz01操作安装。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

discuz01 主机的 html 目录同步给 discuz02 主机(此时项目中已经包含了连接数据库的相关信息)

[root@discuz01 ~]# scp -r /usr/share/nginx/html 192.168.226.130:/usr/share/nginx/

discuz02 主机修改 html 目录下项目文件权限

[root@discuz02 ~]# cd /usr/share/nginx/html/
[root@discuz02 html]# chown -R nginx.nginx .

访问 discuz02 测试:http://192.168.226.130/

上面我只对discuz01安装拉这个项目,而discuz02没有安装,将主机discuz01的html目录拷贝到discuz02,现在主机discuz02

没有安装也可以访问到项目网页,这样就完成拉集群操作,同理,可以部署更多的服务主机用不同的主机都可以访问同一个网站。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Redis为论坛提供缓存

通过 Redis 缓存数据库将论坛数据存储在内存中,使其能够处理高并发的读写操作,每秒可以执行高达数十万次的读写操作,来提高论坛的性能。

discuz-db 主机安装Redis数据库

[root@discuz-db ~]# yum install redis -y

Redis 默认只允许本地访问,需要修改 Redis 配置文件允许远程访问

[root@discuz-db ~]# vim /etc/redis.conf +61#查找 bind 127.0.0.1 这一行修改为0.0.0.0 监听所有接口。如下所示:
bind 0.0.0.0

启动 Redis 服务

[root@discuz-db ~]# systemctl start redis
[root@discuz-db ~]# systemctl enable redis

Discuz 中检查是否支持 Redis

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

默认不支持 Redis 缓存,Discuzphp 语言开发,如需通过 Redis提供缓存,需要安装 php 连接 Redis 的扩展模块。

discuz01和discuz02 主机安装 php-pecl-redis 扩展模块

yum -y install php-pecl-redis

两台都重启 php-fpm 并检查是否支持 redis

systemctl restart php-fpm
php -m | grep redis

再次刷新Discuz页面检查是否支持Redis

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

但是现在 DiscuzRedis 之间还没有建立连接,接下来配置Discuz连接 Redis

discuz01discuz02 主机修改文件:/usr/share/nginx/html/config/config_global.php

vim /usr/share/nginx/html/config/config_global.php +19
#...#指定Redis服务器地址
$_config['memory']['redis']['server'] = '192.168.226.128'; 

再次刷新页面可看到Discuz已经成功与Redis连接,并且已经利用Redis存储了数据。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Nginx为Discuz实现负载均衡

负载均衡通过分散流量到多台服务器,避免单一服务器负载过重,提高系统性能和响应速度

配置多个负载均衡节点,当其中一个节点发生故障,其他节点可以接管其工作,避免业务中断。

主机名IP地址操作系统硬件配置
master-proxy192.168.226.131CentOS 72 Core/4G Memory
backup-proxy192.168.226.132CentOS 72Core/4G Memory

再准备两台虚拟机分别修改主机名修改主机名

#对192.168.226.131操作
hostnamectl set-hostname master-proxy
#对192.168.226.132操作
hostnamectl set-hostname backup-proxy

两台机器安装 Nginx 软件包

vim /etc/yum.repos.d/nginx.repo[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
yum install nginx-1.20.2 -y

创建 Nginx 代理配置文件,实现代理功能

rm -rf /etc/nginx/conf.d/*
vim /etc/nginx/conf.d/proxy.confupstream web {server 192.168.226.129:80;   #这里你要修改成discuz01的IP 注意改成你的server 192.168.226.130:80;   #这里改成discuz02的IP
}server {listen       80;server_name  web.discuz.com;#开启nginx状态页面location = /status {    stub_status;}location / {proxy_pass http://web;}location ~ .* {proxy_pass http://web;proxy_set_header Host $http_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
}

两台代理主机都启动 Nginx 程序

systemctl start nginx
systemctl enable nginx

访问两台代理测试:

http://192.168.226.131/

http://192.168.226.132/

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Keepalived为Nginx实现高可用

通过 keepalivedNginx 代理实现高可用,当其中一个代理节点发生故障,keepalived 可以实现故障自动切换,避免业务中断。

在两台代理节点安装 keepalived 软件包

yum install keepalived -y

master-proxy 主机修改 keepalived 配置文件

vim /etc/keepalived/keepalived.conf! Configuration File for keepalived
global_defs {router_id LVS_DEVEL
script_user rootenable_script_security
}
vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"interval 5weight -5fall 2
rise 1
}
vrrp_instance VI_1 {state MASTER               interface ens33      #这里的ens33是我的网卡,你要注意你的网卡是什么,再修改         virtual_router_id 51priority 101          #这里是优先级 和备用代理节点的优先级数字不能一样    advert_int 2authentication {auth_type PASSauth_pass abc123}virtual_ipaddress {192.168.226.111/24    #这个虚拟IP自定义,但需要在同一个网段并没有占用的IP }track_script {chk_nginx        }
}

backup-proxy 主机修改keepalived配置文件

vim /etc/keepalived/keepalived.conf ! Configuration File for keepalived
global_defs {router_id LVS_DEVEL
script_user rootenable_script_security
}
vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"interval 5weight -5fall 2
rise 1
}
vrrp_instance VI_1 {state BACKUP               interface ens33       #这里的ens33是我的网卡,你要注意你的网卡是什么,再修改         virtual_router_id 51priority 99             #这里是优先级 和主代理机的优先级数字不能一样   advert_int 2authentication {auth_type PASSauth_pass abc123}virtual_ipaddress {192.168.226.111/24   #这个虚拟IP自定义,但需要在同一个网段并没有占用的IP}track_script {chk_nginx        }
}

keepalived的配置文件详解

#定义一个自定义脚本,名称为chk_nginx
vrrp_script chk_nginx {#脚本所在的路径及名称script "/etc/keepalived/check_nginx.sh"#监控检查的时间间隔,单位秒interval 5#健康检查的次数,连续2次健康检查失败,服务器将被标记为不健康fall 2#连续健康检查成功的次数,有1次健康检查成功,服务器将被标记为健康rise 1
}#配置了一个名为VI_1VRRP实例组
vrrp_instance VI_1 {#该节点在VRRP组中的身份,Master节点负责处理请求并拥有虚拟IP地址state MASTER#实例绑定的网络接口,实例通过这个网络接口与其他VRRP节点通信,以及虚拟IP地址的绑定interface ens32#虚拟的路由ID,范围1255之间的整数,用于在一个网络中区分不同的VRRP实例组,但是在同一个VRRP组中的节点,该ID要保持一致virtual_router_id 51#实例的优先级,范围1254之间的整数,用于决定在同一个VRRP组中哪个节点将成为Master节点,数字越大优先级越>高priority 101#Master节点广播VRRP报文的时间间隔,用于通知其他Backup节点Master节点的存在和状态,在同一个VRRP组中,所有>节点的advert_int参数值必须相同advert_int 2#实例之间通信的身份验证机制authentication {#PASS为密码验证auth_type PASS#此密码必须为18个字符,在同一个VRRP组中,所有节点必须使用相同的密码,以确保正确的身份验证和通信auth_pass abc123}#定义虚拟IP地址virtual_ipaddress {192.168.0.111/24      }#引用自定义脚本,名称与上方vrrp_script中定义的名称保持一致track_script {chk_nginx}
}

在两台主机的 /etc/keepalived/ 目录准备 check_nginx.sh 脚本

vim /etc/keepalived/check_nginx.sh#!/bin/bash
conut=`ps -C nginx | grep -v PID | wc -l`
if [ $conut -eq 0 ];thensystemctl stop keepalived
fi

为脚本添加执行权限

chmod +x /etc/keepalived/check_nginx.sh

两台主机启动 keepalived 服务

systemctl start keepalived
systemctl enable keepalived

master-proxy 主机查看 keepalived 虚拟IP地址

[root@master-proxy ~]# ip a
#...
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 #本机IPinet 192.168.226.131/24 brd 192.168.226.255 #keepalived虚拟IPinet 192.168.226.111/24 scope global secondary ens33

windows 的 hosts 文件中配置本地解析:C:\Windows\System32\drivers\etc\hosts

注:建议用记事本的管理员身份运行去修改这个配置文件,普通身份可能会失败

192.168.226.111 web.discuz.com

访问域名测试:http://web.discuz.com/

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

测试备用代理,当主代理的Nginx挂掉,Keepalived会将使用备用代理

将master-proxy主机关闭nginx,观察备用代理的IP

#关闭nginx服务
systemctl stop nginx   
#查看keepalived  正常是同时关闭拉
systemctl status keepalived    

在备用代理backup-proxy查看IP

[root@master-proxy ~]# ip a
#...
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 #本机IPinet 192.168.226.132/24 brd 192.168.226.255 #keepalived虚拟IPinet 192.168.226.111/24 scope global secondary ens33 ~]# ip a
#可以看到虚拟IP现在成功切换到拉备用代理主机上拉

现在再切换回master-proxy主机开启nginx和keepalived并查看master-proxy的IP

systemctl start nginx keepalived[root@master-proxy ~]# ip a
#...
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 #本机IPinet 192.168.226.131/24 brd 192.168.226.255 #keepalived虚拟IPinet 192.168.226.111/24 scope global secondary ens33

可以发现,当主代理nginx挂掉,就成功让keepalived也关闭,从而使虚拟IP成功切换到备用代理机上,当主代理机恢复nginx和keepalived服务后,主代理机又拿回拉虚拟IP,至此成功实现了高可用。

将master-proxy主机关闭nginx,观察备用代理的IP

#关闭nginx服务
systemctl stop nginx   
#查看keepalived  正常是同时关闭拉
systemctl status keepalived    

在备用代理backup-proxy查看IP

[root@master-proxy ~]# ip a
#...
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 #本机IPinet 192.168.226.132/24 brd 192.168.226.255 #keepalived虚拟IPinet 192.168.226.111/24 scope global secondary ens33 ~]# ip a
#可以看到虚拟IP现在成功切换到拉备用代理主机上拉

现在再切换回master-proxy主机开启nginx和keepalived并查看master-proxy的IP

systemctl start nginx keepalived[root@master-proxy ~]# ip a
#...
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 #本机IPinet 192.168.226.131/24 brd 192.168.226.255 #keepalived虚拟IPinet 192.168.226.111/24 scope global secondary ens33

可以发现,当主代理服务器发生故障后,Keepalived会自动把IP切换到备用代理服务器上,当主代理恢复服务后,又从新换回来,从而达到代理服务器的高可用效果。

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

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

相关文章

一键复制:基于vue实现的tab切换效果

需求&#xff1a;顶部栏有切换功能&#xff0c;内容区域随顶部切换而变化 目录 实现效果实现代码使用示例在线预览 实现效果 如下 实现代码 组件代码 MoTab.vue <template><div class"mo-tab"><divv-for"item in options"class"m…

OBS插件--视频回放

视频回放 视频回放是一款源插件&#xff0c;它可以将指定源的视频缓存一段时间&#xff08;时间可以设定&#xff09;&#xff0c;将缓存中的视频添加到当前场景中后&#xff0c;可以快速或慢速不限次数的回放。这个功能在类似体育比赛的直播中非常有用&#xff0c;可以捕获指…

网络基础(三)——网络层

目录 IP协议 1、基本概念 2、协议头格式 2.1、报头和载荷如何有效分离 2.2、如果超过了MAC的规定&#xff0c;IP应该如何做呢&#xff1f; 2.3、分片会有什么影响 3、网段划分 4、特殊的ip地址 5、ip地址的数量限制 6、私有ip地址和公网ip地址 7、路由 IP协议 网络…

C++/Qt 小知识记录6

工作中遇到的一些小问题&#xff0c;总结的小知识记录&#xff1a;C/Qt 小知识6 dumpbin工具查看库导出符号OSGEarth使用编出的protobuf库&#xff0c;报错问题解决VS2022使用cpl模板后&#xff0c;提示会乱码的修改设置QProcess调用cmd.exe执行脚本QPainterPath对线段描边处理…

实验0.0 Visual Studio 2022安装指南

Visual Studio 2022 是一个功能强大的开发工具&#xff0c;对于计算机专业的学生来说&#xff0c;它不仅可以帮助你完成学业项目&#xff0c;还能为你将来的职业生涯打下坚实的基础。通过学习和使用 Visual Studio&#xff0c;你将能够更高效地开发软件&#xff0c;并在编程领域…

picoCTF-Web Exploitation-More SQLi

Description Can you find the flag on this website. Additional details will be available after launching your challenge instance. Hints SQLiLite 先随便输入个账号密码登录一下&#xff0c;得到查询SQL&#xff0c;接下来应该对SQL进行某些攻击来绕过密码登录成功 -- …

Unity Editor 找物体助手

找啊找朋友~ &#x1f371;功能介绍&#x1f959;使用方法 &#x1f371;功能介绍 &#x1f4a1;输入相关字符串&#xff0c;它会帮你找到名称中带有该字符串的所有物体&#xff0c;还会找包含该字符串的Text、TextMeshProUGUI。 &#x1f959;使用方法 &#x1f4a1;导入插…

商场学习之微服务

前言 寒假前在新电脑上配置了java环境&#xff0c;maven仓库&#xff0c;node,js&#xff0c;navicat&#xff0c;MySQL&#xff0c;linux&#xff0c;vmware等环境&#xff0c;创建了6个mysql数据库&#xff0c;77张表。 如此多的表&#xff0c;字段&#xff0c;去手写基础…

加州大学欧文分校英语高级语法专项课程01:Verb Tenses and Passives 学习笔记

Verb Tenses and Passives Course Certificate Course Intro 本文是学习 Verb Tenses and Passives 这门课的学习笔记。 文章目录 Verb Tenses and PassivesWeek 01: Simple, Progressive, and Perfect Verb Tenses ReviewLearning Objectives Present Perfect Tense Review L…

从我的实体书单中,精选这六本书推荐

工作之余偶尔看看书&#xff0c;偏爱翻阅实体书。随着时间的推移&#xff0c;书逐渐变得多了起来。为了给新书腾出空间&#xff0c;同时也为了减轻收藏实体书的经济负担&#xff0c;我决定进行一次书籍的整理和出售。在这一过程中&#xff0c;我特意挑选了六本我个人喜爱的书籍…

《构建智能财务预算与管控技术架构:实现企业财务管理的高效运作》

在当今数字化时代&#xff0c;企业财务预算与管控技术的应用已成为企业管理的关键一环。通过构建智能化的财务预算与管控技术架构&#xff0c;企业能够实现财务管理的精细化、智能化和高效化&#xff0c;从而更好地应对市场竞争和风险挑战&#xff0c;提升企业的竞争力和盈利能…

i春秋-GetFlag

题目 考点 sql注入&#xff0c;md5加密&#xff0c;代码审计&#xff0c;利用eval函数 解题 参考wp https://www.cnblogs.com/qiaowukong/p/13630130.html找md5值 看见验证码中的提示&#xff0c;就是去找一个md5值前六位是指定值的数&#xff08;严格来说不一定是数&…

【C语言项目】贪吃蛇(下)

个人主页~ 源码在Gitee仓库~ 上一篇贪吃蛇&#xff08;上&#xff09;~ 贪吃蛇 四、核心的实现游戏测试1、GameStart&#xff08;1&#xff09;控制台窗口大小和名字设置&#xff08;2&#xff09;光标隐藏&#xff08;3&#xff09;打印欢迎界面&#xff08;4&#xff09;创建…

鸿蒙布局Column/Row/Stack

鸿蒙布局Column/Row/Stack 简介我们以Column为例进行讲解1. Column({space: 10}) 这里的space: 10&#xff0c;表示Column里面每个元素之间的间距为102. width(100%)&#xff0c;height(100%) 表示宽高占比3. backgroundColor(0xffeeeeee) 设置背景颜色4. padding({top: 50}) 设…

Vue报错:TypeError: Cannot read property ‘upgrade‘ of undefined

文章目录 Vue报错&#xff1a;TypeError: Cannot read property upgrade of undefined前言解决办法 Vue报错&#xff1a;TypeError: Cannot read property ‘upgrade’ of undefined 前言 最近打开一个很就之前的开发项目&#xff0c;因为扫描包&#xff0c;所以删除了部分代…

如何从未入库的gerrit中撤销一个文件

用一个例子说明 比如有一个提交里面的default.xml的修改没有必要&#xff0c;需要从未入库的gerrit中移除 步骤如下&#xff1a; 1.做reset操作 git reset HEAD^ packages/SettingsProvider/res/values/defaults.xml 2.做checkout操作 git checkout packages/SettingsProv…

【C++】STL-list的使用

目录 1、list的使用 1.1 list的构造 1.2 list的遍历 1.3 list capacity 1.4 list element access 1.5 容量相关 list是一个带头双向循环链表 1、list的使用 1.1 list的构造 1.2 list的遍历 list只有两种遍历方式&#xff0c;因为没有operator[] 因为list的双向链表&am…

13.跳跃游戏

文章目录 题目简介题目解答解法一&#xff1a;贪心算法&#xff0b;动态规划代码&#xff1a;复杂度分析&#xff1a; 题目链接 大家好&#xff0c;我是晓星航。今天为大家带来的是 跳跃游戏面试题 相关的讲解&#xff01;&#x1f600; 题目简介 题目解答 思路&#xff1a;这…

vscode打开esp-idf工程,找不到头文件,有波浪线

就像这样 多半是因为原始的工程不是用vscode的插件新建的&#xff0c;因此没有相关的路径。需要在工程文件夹下的.vscode文件夹中的c_cpp_properties.json文件中增加路径&#xff0c;可以参考插件自动新建的工程里面的写法 {"configurations": [{"name":…

LabVIEW二维码生成与识别

LabVIEW二维码生成与识别 随着数字化时代的快速发展&#xff0c;QR二维码作为一种高效的信息传递和识别手段&#xff0c;已广泛应用于各行各业。利用LabVIEW软件及其NI视觉开发模块(VDM)来实现一个高效的QR二维码生成与识别系统。该系统不仅能够快速生成带有自定义信息的二维码…