当前位置: 首页 > news >正文

【网站架构部署与优化】源码编译安装LAMP

文章目录

  • LAMP架构概述
    • 各组件的主要作用
    • 构建LAMP平台的安装顺序
  • 编译安装Apache httpd服务指南
    • 1. 准备工作
      • 1.1 关闭防火墙并传输软件包
      • 1.2 安装环境依赖包
    • 2. 配置软件模块
      • 2.1 解压软件包
      • 2.2 移动apr组件包
      • 2.3 配置httpd
    • 3. 编译及安装
    • 4. 优化配置
      • 4.1 配置文件路径
      • 4.2 添加httpd系统服务
        • 方法一:使用init.d
        • 方法二:使用systemd
    • 5. 修改httpd服务配置文件
      • 5.1 编辑httpd.conf
      • 5.2 检查配置文件并重启服务
    • 6. 浏览器访问验证
      • 6.1 检查端口监听
      • 6.2 添加hosts记录
      • 6.3 访问测试
  • 编译安装MySQL服务完整指南
    • 一、前期准备
    • 二、配置与编译
    • 三、设置与启动
    • 四、安全配置
      • 注意事项
  • 编译安装PHP解析环境及论坛搭建指南
    • 一、编译安装PHP解析环境
    • 二、安装论坛
    • 注意

LAMP架构概述

LAMP架构是企业级网站应用开发中广泛采用的一种成熟模式,它代表了一套协同工作的系统和软件组合,专为提供动态Web站点服务及其应用开发环境而设计。LAMP是Linux、Apache、MySQL、PHP(或Perl、Python)四个组件首字母的缩写,每个组件都扮演着关键角色。

各组件的主要作用

  1. Linux(平台)
    • 作为LAMP架构的基础,Linux提供了稳定且高效的操作系统环境,为Web站点提供坚实的支撑。其强大的兼容性和稳定性使得AMP组件(Apache、MySQL、PHP/Perl/Python)能够在其上顺畅运行,同时也支持跨平台部署,尽管AMP本身也兼容Windows、UNIX等平台。
  2. Apache(前台)
    • 作为LAMP架构的前端,Apache是一款广受欢迎的Web服务器软件,以其强大的功能和卓越的稳定性著称。它直接面向用户,负责处理来自客户端的请求,发送网页、图片等文件内容,是用户与Web站点之间交互的桥梁。
  3. MySQL(后台)
    • MySQL是LAMP架构中的数据库服务器组件,是一款开源的关系数据库管理系统。它负责存储网站和应用程序所需的各种数据,如账户信息、产品信息、客户资料、业务数据等。通过SQL语句,其他程序可以方便地查询、更新这些信息,实现数据的动态管理和交互。
  4. PHP/Perl/Python(中间连接)
    • 这三种编程语言在LAMP架构中扮演着沟通Web服务器和数据库系统的关键角色。它们负责解释和执行动态网页文件,将用户请求的数据传递给数据库,并将数据库返回的结果以网页形式展示给用户。其中,PHP因其易于学习、广泛支持和与HTML紧密集成的特性,在Web应用开发中尤为受欢迎。

构建LAMP平台的安装顺序

在构建LAMP平台时,通常按照Linux、Apache、MySQL、PHP的顺序进行安装。虽然Apache和MySQL的安装顺序并不严格,但PHP环境的安装一般放在最后,以确保它能够正确地与Web服务器和数据库系统协同工作。这样的安装顺序有助于避免依赖性问题,并确保整个系统的稳定性和兼容性。

编译安装Apache httpd服务指南

1. 准备工作

1.1 关闭防火墙并传输软件包

systemctl stop firewalld
systemctl disable firewalld
setenforce 0

将以下软件包传到/opt目录下:

  • httpd-2.4.29.tar.gz
  • apr-1.6.2.tar.gz
  • apr-util-1.6.0.tar.gz

1.2 安装环境依赖包

yum -y install gcc gcc-c++ make pcre pcre-devel expat-devel perl

2. 配置软件模块

2.1 解压软件包

cd /opt/
tar zxvf apr-1.6.2.tar.gz
tar zxvf apr-util-1.6.0.tar.gz
tar jxvf httpd-2.4.29.tar.bz2

2.2 移动apr组件包

mv apr-1.6.2 /opt/httpd-2.4.29/srclib/apr
mv apr-util-1.6.0 /opt/httpd-2.4.29/srclib/apr-util

2.3 配置httpd

cd /opt/httpd-2.4.29/
./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi

3. 编译及安装

make
make install

4. 优化配置

4.1 配置文件路径

ln -s /usr/local/httpd/conf/httpd.conf /etc/
ln -s /usr/local/httpd/bin/* /usr/local/bin/

4.2 添加httpd系统服务

方法一:使用init.d
cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
chmod +x /etc/init.d/httpd
# 编辑/etc/init.d/httpd文件,添加以下内容:
#!/bin/bash
# chkconfig: 35 85 21
# description: Apache is a World Wide Web server
chkconfig --add httpd
systemctl start httpd.service
# 或
service httpd start
方法二:使用systemd
vim /lib/systemd/system/httpd.service
# 编辑httpd.service文件,添加或修改以下内容:
[Unit]
Description=The Apache HTTP Server
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/httpd/logs/httpd.pid
ExecStart=/usr/local/bin/apachectl $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
[Install]
WantedBy=multi-user.target
systemctl start httpd.service
systemctl enable httpd.service

5. 修改httpd服务配置文件

5.1 编辑httpd.conf

vim /etc/httpd.conf
# 修改以下行:
Listen 192.198.80.10:80
ServerName www.kgc.com:80
DocumentRoot "/usr/local/httpd/htdocs"
DirectoryIndex index.html

5.2 检查配置文件并重启服务

httpd -t  # 或 apachectl -t
systemctl restart httpd.service

6. 浏览器访问验证

6.1 检查端口监听

netstat -anpt | grep 80

6.2 添加hosts记录

echo "192.168.80.10 www.kgc.com" >> /etc/hosts

6.3 访问测试

在浏览器中输入以下地址进行测试:

  • http://192.168.80.10
  • http://www.kgc.com

编译安装MySQL服务完整指南

一、前期准备

  1. 传输软件包
    将以下软件包传输到/opt目录下:
    • mysql-5.7.17.tar.gz
    • boost_1_59_0.tar.gz (支持C++的运行库)
  2. 安装环境依赖包
    运行以下命令安装必要的编译工具和库:
    gcc
    gcc-c++
    ncurses \ #字符终端下图形互动功能的动态库
    ncurses-devel \ #ncurses开发包
    bison \ #语法分析器
    cmake #mysql需要用cmake编译安装
    yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake openssl-devel
    

二、配置与编译

  1. 解压软件包

    tar zxvf mysql-5.7.17.tar.gz
    tar zxvf boost_1_59_0.tar.gz
    cd /opt
    mv boost_1_59_0 /usr/local/boost #重命名
    
  2. 配置CMake
    进入MySQL源码目录并执行CMake配置:

    cd /opt/mysql-5.7.17/
    cmake \
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #指定mysql的安装路径
    -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ #指定mysql进程监听套接字文件(数据库连接文件)的存储路径
    -DSYSCONFDIR=/etc \#指定配置文件的存储路径
    -DSYSTEMD_PID_DIR=/usr/local/mysql \#指定进程文件的存储路径
    -DDEFAULT_CHARSET=utf8 \#指定默认使用的字符集编码,如 utf8
    -DDEFAULT_COLLATION=utf8_general_ci \#指定默认使用的字符集校对规则
    -DWITH_EXTRA_CHARSETS=all \#指定支持其他字符集编码
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \#安装INNOBASE存储引擎
    -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ #安装ARCHIVE存储引擎 
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \  #安装BLACKHOLE存储引擎 
    -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ #安装FEDERATED存储引擎 
    -DMYSQL_DATADIR=/usr/local/mysql/data \#指定数据库文件的存储路径
    -DWITH_BOOST=/usr/local/boost \#指定boost的路径,若使用mysql-boost集成包安装则-DWITH_BOOST=boost
    -DWITH_SYSTEMD=1#生成便于systemctl管理的文件
    

注意:若CMake报错,删除CMakeCache.txt后重试。
存储引擎选项:
MYISAM,MERGE,MEMORY,和CSV引擎是默认编译到服务器中,并不需要明确地安装。
静态编译一个存储引擎到服务器,使用-DWITH_engine_STORAGE_ENGINE= 1
可用的存储引擎值有:ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE (InnoDB), PARTITION (partitioning support), 和PERFSCHEMA (Performance Schema)

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_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1
  1. 编译及安装
    make && make install
    

三、设置与启动

  1. 创建MySQL用户

    useradd -M -s /sbin/nologin mysql
    
  2. 修改MySQL配置文件
    编辑/etc/my.cnf文件,设置相关参数如端口、字符集、数据目录等。

vim /etc/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=utf8mb4				#设置服务器字符集编码格式为utf8
pid-file = /usr/local/mysql/mysqld.pid		#指定pid 进程文件路径
socket=/usr/local/mysql/mysql.sock			#指定数据库连接文件
bind-address = 0.0.0.0						#设置监听地址,0.0.0.0代表允许所有,如允许多个IP需空格隔开
skip-name-resolve							#禁止域名解析,包括主机名,所以授权的时候要使用 IP 地址
max_connections=4096						#设置mysql的最大连接数
default-storage-engine=INNODB				#指定默认存储引擎
max_allowed_packet=32M						#设置在网络传输中一次消息传输量的最大值。系统默认值为 1MB,最大值是 1GB,必须设置 1024 的倍数。
server-id = 1								#指定服务ID号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

sql_mode常用值如下:
NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
STRICT_TRANS_TABLES
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_AUTO_CREATE_USER
禁止GRANT创建密码为空的用户
NO_AUTO_VALUE_ON_ZERO
mysql中的自增长列可以从0开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错
NO_ZERO_IN_DATE
不允许日期和月份为零
NO_ZERO_DATE
mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
ERROR_FOR_DIVISION_BY_ZERO
在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MySQL返回NULL
PIPES_AS_CONCAT
将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
ANSI_QUOTES
启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

[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=utf8mb4
pid-file = /usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
max_connections=4096
default-storage-engine=INNODB
max_allowed_packet=32M
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
  1. 更改文件权限

    chown -R mysql:mysql /usr/local/mysql/
    chown mysql:mysql /etc/my.cnf
    
  2. 设置环境变量

    echo 'export PATH=/usr/local/mysql/bin:$PATH' >> /etc/profile
    source /etc/profile
    
  3. 初始化数据库

    cd /usr/local/mysql/bin/
    ./mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
    
--initialize-insecure \				#生成初始化密码为空
--user=mysql \                      #指定管理用户
--basedir=/usr/local/mysql \        #指定数据库的安装目录
--datadir=/usr/local/mysql/data		#指定数据库文件的存储路径
  1. 添加系统服务
    cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
    systemctl daemon-reload
    systemctl start mysqld.service
    systemctl enable mysqld
    netstat -anpt | grep 3306
    
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/		#用于systemctl服务管理
systemctl daemon-reload         #刷新识别     
systemctl start mysqld.service  #开启服务
systemctl enable mysqld         #开机自启动
netstat -anpt | grep 3306       #查看端口

四、安全配置

  1. 修改登录密码
    mysqladmin -u root password "abc123"
    
  2. 授权远程登录
    登录MySQL并执行:
    mysql -u root -p
    grant all privileges on *.* to 'root'@'%' identified by 'abc123'; 
    show databases;
    
grant all privileges on *.* to 'root'@'%' identified by 'abc123';
#授予root用户可以在所有终端远程登录,使用的密码是abc123,并对所有数据库和所有表有操作权限show databases;			#查看当前已有的数据库

注意事项

  • 在生产环境中,请务必修改默认的root密码,并限制远程访问权限以提高安全性。
  • 定期备份数据库以防数据丢失。
  • 根据实际需求调整my.cnf中的配置参数。

编译安装PHP解析环境及论坛搭建指南

一、编译安装PHP解析环境

  1. 传输PHP软件包
    php-7.1.10.tar.bz2传输到/opt目录下。

  2. 安装依赖库
    运行以下命令安装GD库及相关依赖:

    yum -y install gd libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel curl curl-devel openssl openssl-devel
    
  3. 配置PHP模块

    cd /opt
    tar xf php-7.1.10.tar.bz2
    cd /opt/php-7.1.10/
    ./configure --prefix=/usr/local/php --with-apxs2=/usr/local/httpd/bin/apxs --with-mysql-sock=/usr/local/mysql/mysql.sock --with-config-file-path=/usr/local/php/lib --with-mysqli --with-zlib --with-curl --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-openssl --enable-mbstring --enable-xml --enable-session --enable-ftp --enable-pdo --enable-tokenizer --enable-zip
    
cd /opt
tar xf php-7.1.10.tar.bz2
cd /opt/php-7.1.10/
./configure \
--prefix=/usr/local/php \	#指定将 PHP 程序的安装路径
--with-apxs2=/usr/local/httpd/bin/apxs \#指定Apache httpd服务提供的apxs 模块支持程序的文件位置
--with-mysql-sock=/usr/local/mysql/mysql.sock \#指定mysql 数据库连接文件的存储路径
--with-config-file-path=/usr/local/php/lib	#设置 PHP 的配置文件 php.ini 将要存放的位置
--with-mysqli \	#添加 MySQL 扩展支持,mysqli扩展技术不仅可以调用MySQL的存储过程、处理MySQL事务,而且还可以使访问数据库工作变得更加稳定
--with-zlib \	#支持zlib功能,提供数据压缩
--with-curl \	#开启curl扩展功能,实现HTTP的Get下载和Post请求的方法
--with-gd \		#激活gd 库的支持
--with-jpeg-dir \	#激活jpeg 的支持
--with-png-dir \	#激活png 的支持
--with-freetype-dir \
--with-openssl \
--enable-mbstring \	#启用多字节字符串功能,以便支持中文等代码
--enable-xml \	#开启扩展性标记语言模块
--enable-session \	#会话
--enable-ftp \	#文本传输协议
--enable-pdo \	#函数库
--enable-tokenizer \#令牌解释器
--enable-zip	#ZIP压缩格式
  1. 编译及安装PHP

    make && make install
    
  2. 设置环境变量
    创建符号链接以便系统识别PHP可执行程序:

    ln -s /usr/local/php/bin/* /usr/local/bin/
    php -m  # 查看加载的模块
    
  3. 配置PHP主文件
    复制并修改php.ini文件:

    cp /opt/php-7.1.10/php.ini-development /usr/local/php/lib/php.ini#在测试环境时使用php.ini-development文件,而在生产环境时使用php.ini-production文件
    vim /usr/local/php/lib/php.ini  # 修改mysqli.default_socket和date.timezone
    --1170行--修改
    mysqli.default_socket = /usr/local/mysql/mysql.sock
    --939行--取消注释,修改
    date.timezone = Asia/Shanghai
    
  4. 配置Apache支持PHP
    编辑httpd.conf文件以添加PHP类型支持并修改首页文件:

    vim /etc/httpd.conf
    # 插入AddType行并修改DirectoryIndex
    --393行--插入以下内容
    AddType application/x-httpd-php .php
    AddType application/x-httpd-php-source .phps
    --255行--修改首页文件名设置
    DirectoryIndex index.html index.php
    #---检查支持php7的模块是否存在------
    LoadModule php7_module        modules/libphp7.so
    
  5. 验证PHP测试页
    创建index.php文件并重启Apache服务,然后在浏览器中访问测试。

    rm -rf /usr/local/httpd/htdocs/index.html
    vim /usr/local/httpd/htdocs/index.php
    <?php
    phpinfo();
    ?>systemctl restart httpd.service
    

浏览器访问
http://192.168.80.10(主机地址)

二、安装论坛

  1. 创建数据库并授权
    登录MySQL创建数据库及用户,并授予权限:

    mysql -u root -p
    CREATE DATABASE bbs;#创建数据库
    GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';#把bbs数据库里面所有表的权限授予给bbsuser,并设置密码admin123
    flush privileges;#刷新数据库
    show databases;
    
  2. 解压论坛压缩包
    解压并将论坛文件复制到Apache的htdocs目录下:

    unzip /opt/Discuz_X3.4_SC_UTF8.zip -d /opt/dis
    cd /opt/dis/dir_SC_UTF8/
    cp -r upload/ /usr/local/httpd/htdocs/bbs#上传站点更新包
    
  3. 更改论坛目录权限
    根据论坛进程用户名修改相关目录权限:

    chown -R daemon ./config ./data ./uc_client ./uc_server/data
    
  4. 验证论坛访问
    在浏览器中访问论坛页面及后台管理员页面进行验证。

论坛页面访问:
http://192.168.80.10/bbs

数据库服务器:localhost #本地架设就用localhost,如何不是在在本机上就要填写IP地址和端口号
数据库名字:bbs
数据库用户名:bbsuser
数据库密码:admin123
管理员账号:admin
管理员密码:admin123

论坛后台管理员页面
http://192.168.80.10/bbs/admin.php

注意

  • 确保所有路径和配置文件中的设置正确无误。
  • 根据实际环境调整数据库服务器地址、端口及登录凭证。
  • 定期备份重要数据和配置文件以防丢失。
  • 在生产环境中加强安全设置,如限制远程访问、使用强密码等。

相关文章:

【网站架构部署与优化】源码编译安装LAMP

文章目录 LAMP架构概述各组件的主要作用构建LAMP平台的安装顺序 编译安装Apache httpd服务指南1. 准备工作1.1 关闭防火墙并传输软件包1.2 安装环境依赖包 2. 配置软件模块2.1 解压软件包2.2 移动apr组件包2.3 配置httpd 3. 编译及安装4. 优化配置4.1 配置文件路径4.2 添加http…...

【Linux】Linux的基本指令(1)

A clown is always a clown.&#x1f493;&#x1f493;&#x1f493; 目录 ✨说在前面 &#x1f34b;知识点一&#xff1a;Linux的背景 •&#x1f330;1.Unix发展的历史 •&#x1f330;2.Linux发展历史 •&#x1f330;3.企业应用现状 •&#x1f330;4.发行版本 &…...

Python安装虚拟环境Conda

这里写自定义目录标题 Conda介绍Conda下载与安装下载地址安装检查是否安装成功Conda中的几个重要目录 envs、pkgspkgs文件夹envs文件夹 Conda 使用教学查看 Conda 自带库配置下载源设置下载时显示通道地址创建Conda 环境查看Conda 环境克隆环境Conda 环境导出环境配置从配置文件…...

基于STM32设计的烘干车间远程控制系统(腾讯云IOT)(228)

文章目录 一、前言1.1 项目介绍【1】项目背景【2】设计实现的功能【3】项目硬件模块组成1.2 设计思路【1】整体设计思路【2】ESP8266工作模式配置1.3 项目开发背景【1】选题的意义【2】可行性分析【3】参考文献【4】项目背景【5】摘要1.4 开发工具的选择【1】设备端开发【2】上…...

Nginx泛域名 解析的匹配前缀绑定或转发到子目录

网站的目录结构为&#xff1a; # tree /home/wwwroot/landui.com /home/wwwroot/landui.com ├── bbs │ └── index.html └── www └── index.html 2 directories, 2 files /home/wwwroot/landui.com为nginx的安装目录下默认的存放源代码的路径。 bbs为论坛…...

黑神话悟空mac可以玩吗

黑神话悟空mac上能不能玩对于苹果玩家来说很重要&#xff0c;那么黑神话悟空mac可以玩吗&#xff1f;目前是玩不了了&#xff0c;没有针对ios系统的版本&#xff0c;只能之后在云平台上找找了&#xff0c;大家可以再观望下看看。 黑神话悟空mac可以玩吗 ‌使用CrossOver‌&…...

Nuxt Kit 中的插件:创建与使用

title: Nuxt Kit 中的插件:创建与使用 date: 2024/9/19 updated: 2024/9/19 author: cmdragon excerpt: 摘要:本文介绍了在 Nuxt 3 框架中使用 Nuxt Kit 创建和管理插件的方法,包括使用addPlugin注册插件、创建插件文件、在Vue组件中使用插件,以及使用addPluginTemplate…...

C++(虚构造与虚析构/类型信息运算符/强制类型转换)

一、虚构造与虚析构 1、构造函数能否是虚函数&#xff0c;为什么&#xff1f; 对象有创建过程&#xff1a; 1、给对象分配内存 2、根据继承表顺序调用父类构造 3、根据成员对象的的定义顺序调用成员对象的构造函数 4、执行对象自己的构造函数 如果父类的构造函数函数设计…...

python毕业设计基于django+vue医院社区医疗挂号预约综合管理系统7918h-pycharm-flask

目录 技术栈和环境说明预期达到的目标具体实现截图系统设计Python技术介绍django框架介绍flask框架介绍解决的思路性能/安全/负载方面可行性分析论证python-flask核心代码部分展示python-django核心代码部分展示操作可行性技术路线感恩大学老师和同学详细视频演示源码获取 技术…...

tidb 集群搭建

官网的搭建文档&#xff1a;使用 TiUP 部署 TiDB 集群 | TiDB 文档中心 我本地使用三台 centos7.9 服务器搭建&#xff0c;要保证三台服务器之间是可以互相通信的&#xff1b; 搭建集群的命令在其中一台服务器上执行即可&#xff1b; 1、安装tiup&#xff1a; curl --proto …...

SpringBoot开发——Spring Boot Controller 最佳实践

文章目录 1、RESTful接口地址的定义规则2、设计通用控制器基类3、统一的返回对象设计4、统一的异常处理5、实际案例: 订单控制器 (OrderController)结论 随着微服务架构的普及&#xff0c;RESTful API已经成为现代Web服务的标准设计模式。Spring Boot为开发者提供了强大的工具来…...

使用Ubuntu耳机输出正弦波信号

最近有一个项目想使用喇叭发出一个标准的正弦波测试信号&#xff0c;故记录下操作过程 sudo apt install libasound2-dev 否则有可能会报错&#xff1a; alsaaudio.c:28:10: fatal error: alsa/asoundlib.h: No such file or directory 安装pyalsaaudio&#xff1a; pip …...

Python编程 - 协程

前言 上篇文章主要讲述了python的进程&#xff0c;进程池和进程与线程对比等知识&#xff0c;接下来这篇文章再唠唠python的协程&#xff0c;让我们继续往下看&#xff01; 一、协程的使用 python 中的协程是一种用于处理并发任务的高效工具&#xff0c;它依赖于 asyncio 库以…...

如何在没有备份的情况下恢复 Mac 上丢失的数据

Mac 是您数字世界的中心。它上面可能保存着照片和视频等回忆&#xff0c;以及您不再联系的朋友和家人发来的旧电子邮件。您可能花了数小时导入整个 CD 收藏。您还可能保存着重要文档&#xff0c;例如演示文稿和工作文件、家庭账户或学校或大学的作业。 如果由于某种原因您丢失…...

SpringBoot:解析excel

解析Excel文件&#xff0c;可以使用Apache POI库 <dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.2</version> </dependency> 上代码&#xff1a; /*** <b>Functio…...

Tomcat窗口运行修改窗口标题显示项目日期时间

1、修改配置文件catalina.bat文件 在Tomcat路径 bin文件夹下 set TITLETomcat.xxx.Server [%DATE% %TIME%] 显示&#xff1a;Tomcat.xxx,Server [2024/09.18 周三 12:01:30]...

8-----手机机型维修工具助手 功能较全 涵盖解锁 刷机 修复等选项 维修推荐

上图是一款功能较全的维修加密狗。目前可以无限制 任何人使用。看图片可以了解其中涵盖刷机 解锁 修复分区 查看短接图 安装驱动 修复基带等等选项。而且其中有针对各个机型型号的对应功能操作。以及一些rec5.0相关的操作选项。 通过此博文了解 ★★★★★此工具涵盖的一些…...

集群聊天服务器项目【C++】(四)cmake介绍和简单使用

我们上次用shell命令和vscode编译链接muduo库服务端代码&#xff0c;本章节实现编写CMakeLists.txt来编译项目。本次简单介绍CMake&#xff0c;并用Cmake编译上次的muduo服务器代码。 1.为什么使用cmake 我们在编译项目时&#xff0c;如果编写Makefile的话&#xff0c;常常会…...

Nginx+Tomcat(负载均衡、动静分离)

目录 一、Nginx概述 1.Nginx应用 二、正向代理和反向代理 1.正向代理 1.1主要作用 1.2工作原理 2.反向代理 2.1主要作用 2.2工作原理 三、负载均衡模式 1.轮询 2.最少连接数 3.IP 哈希 4.加权轮询 5.最少时间算法 6.一致性哈希 四、规划部署负载均衡和反向…...

前端分段式渲染较长文章

实现思路&#xff1a; 1. 后端返回整篇文章。 2. JavaScript 分段处理&#xff1a;将文章按一定的字符或段落长度分割&#xff0c;然后逐步将这些段落追加到页面上。 3. 定时器或递归调用&#xff1a;使用 setInterval 或 setTimeout 来控制段落的逐步渲染。 代码实现示例 …...

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…...

在软件开发中正确使用MySQL日期时间类型的深度解析

在日常软件开发场景中&#xff0c;时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志&#xff0c;到供应链系统的物流节点时间戳&#xff0c;时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库&#xff0c;其日期时间类型的…...

synchronized 学习

学习源&#xff1a; https://www.bilibili.com/video/BV1aJ411V763?spm_id_from333.788.videopod.episodes&vd_source32e1c41a9370911ab06d12fbc36c4ebc 1.应用场景 不超卖&#xff0c;也要考虑性能问题&#xff08;场景&#xff09; 2.常见面试问题&#xff1a; sync出…...

Prompt Tuning、P-Tuning、Prefix Tuning的区别

一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

转转集团旗下首家二手多品类循环仓店“超级转转”开业

6月9日&#xff0c;国内领先的循环经济企业转转集团旗下首家二手多品类循环仓店“超级转转”正式开业。 转转集团创始人兼CEO黄炜、转转循环时尚发起人朱珠、转转集团COO兼红布林CEO胡伟琨、王府井集团副总裁祝捷等出席了开业剪彩仪式。 据「TMT星球」了解&#xff0c;“超级…...

Nuxt.js 中的路由配置详解

Nuxt.js 通过其内置的路由系统简化了应用的路由配置&#xff0c;使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

Angular微前端架构:Module Federation + ngx-build-plus (Webpack)

以下是一个完整的 Angular 微前端示例&#xff0c;其中使用的是 Module Federation 和 npx-build-plus 实现了主应用&#xff08;Shell&#xff09;与子应用&#xff08;Remote&#xff09;的集成。 &#x1f6e0;️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...

AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别

【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而&#xff0c;传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案&#xff0c;能够实现大范围覆盖并远程采集数据。尽管具备这些优势&#xf…...

Elastic 获得 AWS 教育 ISV 合作伙伴资质,进一步增强教育解决方案产品组合

作者&#xff1a;来自 Elastic Udayasimha Theepireddy (Uday), Brian Bergholm, Marianna Jonsdottir 通过搜索 AI 和云创新推动教育领域的数字化转型。 我们非常高兴地宣布&#xff0c;Elastic 已获得 AWS 教育 ISV 合作伙伴资质。这一重要认证表明&#xff0c;Elastic 作为 …...