linux安装部署mysql资料
安装虚拟机
等待检查完成
选择中文
软件选择
网络和主机名
开始安装
设置root密码 ADH-password
创建用户
等待安装完成
重启
接受许可证
Centos 7 64安装完成
安装mysql开始
Putty连接指定服务器
在 opt目录下新建download目录 将mysql文件传到该目录下
查看linux服务器的版本,并下载相符合的mysql版本
使用filezilla工具进行文件传输
不知道linux系统机构的,可以执行如下命令查看系统处理器架构 uname -m
若不知道自己的系统信息,可以执行如下命令 cat /etc/os-release
解压文件 tar -xvf mysql-8.0.40-linux-glibc2.17-x86_64.tar.xz
移动文件到/usr/local/mysql路径下
mv mysql-8.0.40-linux-glibc2.17-x86_64 /usr/local/mysql
当/usr/losal/msyql路径不存在时,会自动创建
创建data目录,存储MySQL数据
cd /usr/local/mysql
mkdir data
# MySQL错误日志路径
mkdir data/error
# 日志文件
touch data/error/mysql.log
# 临时文件
mkdir data/tmp
创建用户并添加用户组
groupadd mysql #创建mysql用户组
useradd -g mysql mysql #创建用户mysql,并指定用户的组
为mysql用户分配文件权限
chown -R mysql:mysql /usr/local/mysql
chmod 750 /usr/local/mysql/data
查看/usr/local/mysql文件权限
ll -al /usr/local/mysql
修改or创建mysql的配置文件
vim /etc/my.cnf
[mysqld]
bind-address=0.0.0.0
# 端口
port=3306
# 用户
user=mysql
# mysql根路径
basedir=/usr/local/mysql
# mysql数据路径
datadir=/usr/local/mysql/data
[mysqld_safe]
# 会话信息
socket=/usr/local/mysql/data/tmp/mysql.sock
# 错误日志路径
log-error=/usr/local/mysql/data/error/mysql.log
# 进程存放路径
pid-file=/usr/local/mysql/data/mysql.pid
#character config
# 服务编码格式
character_set_server=utf8mb4
# symbolic-links=0为是否支持符号链接,即数据库或表可以存储在my.cnf中指定datadir之外的分区或目录,为0不开启
symbolic-links=0
# 对column属性是timestamp的处理模式,默认OFF
explicit_defaults_for_timestamp=ON
# 关闭MySQL的only_full_group_by模式
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
#忽略表名大小写
lower_case_table_names=1
[client]
# 客户端默认编码格式
default-character-set=utf8mb4
socket=/usr/local/mysql/data/tmp/mysql.sock
删掉注释后的内容
[mysqld_safe]
socket=/usr/local/mysql/data/tmp/mysql.sock
log-error=/usr/local/mysql/data/error/mysql.log
pid-file=/usr/local/mysql/data/mysql.pid
character_set_server=utf8mb4
symbolic-links=0
explicit_defaults_for_timestamp=ON
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
lower_case_table_names=1
[client]
default-character-set=utf8mb4
socket=/usr/local/mysql/data/tmp/mysql.sock
创建mysql-server服务
cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
/etc/init.d 目录通常用于存放启动脚本,这些脚本用于管理系统服务的启动、停止和重启。
授权授权以及添加服务
chmod +x /etc/init.d/mysql
chkconfig --add mysql
检查mysql服务是否生效
chkconfig --list mysql
数据库初始化
切换到/usr/local/mysql/bin目录下
cd /usr/local/mysql/bin
执行数据库初始化命令
./mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/ --initialize
执行报错 解决如下
再次执行成功,一定要记住初始化的密码
这是这次初始化的密码:JyV%fGC!d1Bc
环境配置与服务启动
配置MySQL全局变量
编辑配置文件
vim /etc/profile.d/mysql_home.sh
写入下面参数配置,:wq!保存退出。
export PATH=$PATH:/usr/local/mysql/bin:/usr/local/mysql/lib
export PATH
设置环境变量立即生效使用source /etc/profile命令
source /etc/profile
启动MySQL服务
service mysql start
报错:解决文件不存在的问题
上传error文件到data目录下
上传tmp文件到data目录下
报错如下 【Starting MySQL. ERROR! The server quit without updating PID file (/usr/local/mysql/data/192.168.1.100.pid).】
解决上面错误
检查权限问题
确保 MySQL 数据目录(/usr/local/mysql/data)及其子目录和文件对 MySQL 用户是可写的。你可以使用 chown 和 chmod 命令来设置正确的权限。
sudo chown -R mysql:mysql /usr/local/mysql/data
sudo chmod -R 755 /usr/local/mysql/data
再运行service mysql start:启动成功
修改密码
使用上述初始化是的原始密码,登录MySQL服务
mysql -uroot -p
修改mysql数据库密码,注意:此处adh-password修改为自己的需要密码即可。
ALTER USER 'root'@'localhost' IDENTIFIED BY 'adh-password';
刷新权限配置&退出
flush privileges;
exit;
重启MySQL服务
service mysql restart
设置远程登录
use mysql;
设置允许远程访问
update user set host='%' where user='root';
刷新权限配置&退出
flush privileges;
exit;
使用Navicat Premium 16工具进行登录验证
新建数据库
创建数据库
运行sql文件
选择好之前备份的sql文件
点击开始
导入完成
再次手动刷新一下库的表
刷新成功,导入成功
Linux系统会对大小写有具体区分
检查是否有任何拼写错误或大小写不匹配的问题(MySQL 在某些操作系统上对表名的大小写敏感)。
关闭防火墙
禁用防火墙: systemctl stop firewalld
禁用开机防火墙 systemctl disable firewalld.service
在usr目录下新建Java目录,然后将下载的JDK拷贝到这个新建的Java目录中
创建目录命令:mkdir /usr/java
上传jdk文件到创建的目录下
进入到Java目录中解压下载的JDK
解压命令:tar -zxvf jdk-8u371-linux-x64.tar.gz
设置环境变量
设置命令:vim /etc/profile
输入上面的命令后,shift+g快速将光标定位到最后一行,然后按“i”,再输入下面代码
export JAVA_HOME=/usr/java/jdk1.8.0_371
export PATH=$JAVA_HOME/bin:$PATH
输入下面命令让设置的环境变量生效
source /etc/profile
验证JDK是否安装成功 java -version
安装tomcat
上传tomcat到目录下
解压命令:tar -zxvf apache-tomcat-9.0.76.tar.gz
在webapps目录下新建目录
上传项目到新建目录下
并进行解压 unzip ARRANGE_V2_Mysql.zip
进行server.xml的项目配置化
在适当位置添加该语句
<Context path="/arrange" docBase="itemArrangeMZ/ARRANGE_V2_Mysql" />
部署完成,运行项目
--进入tomcat的bin目录
cd /home/ioas/Tomcat/apache-tomcat-9.0.76/bin
--运行可查看日志
./catalina.sh run
--直接运行
./startup.sh
项目运行成功
浏览器访问http://192.168.1.100:8080/arrange
设置jdk环境变量的语句 export JAVA_HOME=/usr/java/jdk1.8.0_371
Tomcat设置如何开机自启
创建 tomcat 服务配置文件 vim /etc/init.d/tomcat
JAVA_HOME、CATALINA_HOME改成自己本地对应的路径
#!/bin/bash
# description: Tomcat Start Stop Restart
# processname: tomcat
# chkconfig: 2345 20 80
#idea - tomcat config start
#!/bin/bash
# description: Tomcat Start Stop Restart
# processname: tomcat
# chkconfig: 2345 20 80
JAVA_HOME=/usr/java/jdk1.8.0_371
export JAVA_HOME
PATH=$JAVA_HOME/bin:$PATH
export PATH
CATALINA_HOME=/usr/java/apache-tomcat-9.0.76
case $1 in
start)
sh $CATALINA_HOME/bin/startup.sh
;;
stop)
sh $CATALINA_HOME/bin/shutdown.sh
;;
restart)
sh $CATALINA_HOME/bin/shutdown.sh
sh $CATALINA_HOME/bin/startup.sh
;;
esac
exit 0
#chmod 755 tomcat
#chkconfig --add tomcat
#chkconfig --level 2345 tomcat on
给文件授权 chmod +x /etc/init.d/tomcat
添加到服务列表 chkconfig --add /etc/init.d/tomcat
查看服务列表 chkconfig --list
2,3,4,5都是开表示随系统而启动
启动 tomcat命令 service tomcat start
关闭 tomcat命令 service tomcat stop
重启 tomcat命令 service tomcat restart
实时查看tomcat日志
进入到tomcat的安装目录的logs目录下 运行 tail -f catalina.out
使用 crontab 设置定时重启服务
编写重启tomcat服务的脚本
首先,你需要编写一个 Shell 脚本来重启指定的服务。例如,如果你要重启 Apache HTTP 服务器(通常服务名为 apache2 或 httpd),可以创建一个名为 restart_service.sh 的脚本
确保脚本具有执行权限
chmod +x restart_service.sh
编辑 crontab 文件
使用 crontab -e 命令打开 crontab 编辑器。
添加定时任务
在 crontab 编辑器中,添加一行来指定定时任务和要执行的脚本。crontab 的时间格式如下:
请将 /path/to/restart_service.sh 替换为你实际脚本的路径。
【59 17 * * * /usr/java/restartTask/restart_service.sh】
验证定时任务
你可以通过以下命令查看当前用户的 crontab 定时任务列表,以确保你的任务已正确添加:
crontab -l
关于科大讯飞对接知识(Linux版本)
访问科大讯飞的网站 离线语音合成 - 语音合成 - 讯飞开放平台
点击服务管理 进行sdk的下载
网站下载地址 控制台-讯飞开放平台
下载相对应的sdk版本
这是我本地已下载好的sdk
将下载的sdk文件上传到 /usr/local/tts_server/env/voice 该路径下(没有该目录请依次创建目录)
解压sdk包
解压成功
在新建一个MyDemo的文件夹
然后将 bin、include、libs文件拷到新建的MyDemo文件夹下
命令如下
cd Mydemo
cp ../bin/ ../include/ ../libs/ . -rf
在将/usr/local/tts_server/env/voice/samples 文件夹下的tts_offline_sample拷贝到MyDemo文件夹下
命令如下
cp ../samples/tts_offline_sample . -rf
进入到/usr/local/tts_server/env/voice/Mydemo/tts_offline_sample 的文件夹下 对64bit_make.sh的内容进行修改
命令如下
vim 64bit_make.sh
修改如下
再对 /usr/local/tts_server/env/voice/Mydemo/tts_offline_sample 的文件夹下 对Makefile的内容进行修改
命令如下
vim Makefile
修改如下
对 64bit_make.sh 进行source
命令如下
source 64bit_make.sh
再进行make
Make完之后会在/usr/local/tts_server/env/voice/Mydemo/bin 文件夹下生成 tts_offline_sample该文件
随后我们进行该文件命令的执行
./tts_offline_sample
可以看到语音文件生成成功 ,可以下载到本地进行播放
到该处说明科大讯飞的sdk安装部署完成成功
下一步进行代码的改动、参数可配置话和环境部署
为了实现可配置话,我们需要对/usr/local/tts_server/env/voice/MyDemo/tts_offline_sample 目录下的tts_offline_sample.c 文件进行改造
修改如图
const char* base_path = "/usr/java/apache-tomcat-9.0.76/webapps/itemArrangeMZ/ARRANGE_V2_Mysql/tts/";
注意此处的生成路径是固定的值;需要修改
/* * 语音合成(Text To Speech,TTS)技术能够自动将任意文字实时转换为连续的 * 自然语音,是一种能够在任何时间、任何地点,向任何人提供语音信息服务的 * 高效便捷手段,非常符合信息时代海量数据、动态更新和个性化查询的需求。 */ #include <stdlib.h> #include <stdio.h> #include <unistd.h> #include <errno.h> #include <string.h> #include <inttypes.h> #include <sys/types.h> #include <sys/stat.h> #include <time.h> #include "../include/qtts.h" #include "../include/msp_cmn.h" #include "../include/msp_errors.h" typedef int SR_DWORD; typedef short int SR_WORD ; /* wav音频头部格式 */ typedef struct _wave_pcm_hdr { char riff[4]; // = "RIFF" int size_8; // = FileSize - 8 char wave[4]; // = "WAVE" char fmt[4]; // = "fmt " int fmt_size; // = 下一个结构体的大小 : 16 short int format_tag; // = PCM : 1 short int channels; // = 通道数 : 1 int samples_per_sec; // = 采样率 : 8000 | 6000 | 11025 | 16000 int avg_bytes_per_sec; // = 每秒字节数 : samples_per_sec * bits_per_sample / 8 short int block_align; // = 每采样点字节数 : wBitsPerSample / 8 short int bits_per_sample; // = 量化比特数: 8 | 16 char data[4]; // = "data"; int data_size; // = 纯数据长度 : FileSize - 44 } wave_pcm_hdr; /* 默认wav音频头部数据 */ wave_pcm_hdr default_wav_hdr = { { 'R', 'I', 'F', 'F' }, 0, {'W', 'A', 'V', 'E'}, {'f', 'm', 't', ' '}, 16, 1, 1, 16000, 32000, 2, 16, {'d', 'a', 't', 'a'}, 0 }; /* 文本合成 */ int text_to_speech(const char* src_text, const char* des_path, const char* params) { int ret = -1; FILE* fp = NULL; const char* sessionID = NULL; unsigned int audio_len = 0; wave_pcm_hdr wav_hdr = default_wav_hdr; int synth_status = MSP_TTS_FLAG_STILL_HAVE_DATA; if (NULL == src_text || NULL == des_path) { printf("params is error!\n"); return ret; } fp = fopen(des_path, "wb"); if (NULL == fp) { printf("open %s error.\n", des_path); return ret; } /* 开始合成 */ sessionID = QTTSSessionBegin(params, &ret); if (MSP_SUCCESS != ret) { printf("QTTSSessionBegin failed, error code: %d.\n", ret); fclose(fp); return ret; } ret = QTTSTextPut(sessionID, src_text, (unsigned int)strlen(src_text), NULL); if (MSP_SUCCESS != ret) { printf("QTTSTextPut failed, error code: %d.\n",ret); QTTSSessionEnd(sessionID, "TextPutError"); fclose(fp); return ret; } fwrite(&wav_hdr, sizeof(wav_hdr) ,1, fp); //添加wav音频头,使用采样率为16000 while (1) { /* 获取合成音频 */ const void* data = QTTSAudioGet(sessionID, &audio_len, &synth_status, &ret); if (MSP_SUCCESS != ret) break; if (NULL != data) { fwrite(data, audio_len, 1, fp); wav_hdr.data_size += audio_len; //计算data_size大小 } if (MSP_TTS_FLAG_DATA_END == synth_status) break; } printf("\n"); if (MSP_SUCCESS != ret) { printf("QTTSAudioGet failed, error code: %d.\n",ret); QTTSSessionEnd(sessionID, "AudioGetError"); fclose(fp); return ret; } /* 修正wav文件头数据的大小 */ wav_hdr.size_8 += wav_hdr.data_size + (sizeof(wav_hdr) - 8);
/* 将修正过的数据写回文件头部,音频文件为wav格式 */ fseek(fp, 4, 0); fwrite(&wav_hdr.size_8,sizeof(wav_hdr.size_8), 1, fp); //写入size_8的值 fseek(fp, 40, 0); //将文件指针偏移到存储data_size值的位置 fwrite(&wav_hdr.data_size,sizeof(wav_hdr.data_size), 1, fp); //写入data_size的值 fclose(fp); fp = NULL; /* 合成完毕 */ ret = QTTSSessionEnd(sessionID, "Normal"); if (MSP_SUCCESS != ret) { printf("QTTSSessionEnd failed, error code: %d.\n",ret); } return ret; } int ensure_directory_exists(const char* path) { // 使用F_OK检查文件(或文件夹)是否存在 if (access(path, F_OK) != -1) { // 路径存在,可能是文件或文件夹,但我们假设它是文件夹(这里不进一步区分) printf("\n"); printf("1"); return 0; // 成功,路径已存在 } else { // 路径不存在,尝试创建文件夹 // 注意:mkdir的第二个参数设置了文件夹的权限(如0755表示rwxr-xr-x) if (mkdir(path, 0755) != 0) { // 创建文件夹失败 printf("\n"); printf(path); printf("\n"); printf("2"); printf("\n"); perror("mkdir failed"); return -1; // 失败 } } return 0; // 成功(无论是已存在还是新创建) } char* create_filename(const char* file_path) { const char* base_path = "/usr/java/apache-tomcat-9.0.76/webapps/itemArrangeMZ/ARRANGE_V2_Mysql/tts/"; char date_str[11]; // "YYYY_MM_DD"格式最多需要10个字符+1个空字符 char directory_path[256]; // 足够大的缓冲区来存储完整路径
// 获取当前日期并格式化为"YYYY_MM_DD" time_t rawtime; struct tm *timeinfo; time(&rawtime); timeinfo = localtime(&rawtime); strftime(date_str, sizeof(date_str), "%Y-%m-%d", timeinfo);
// 构建完整路径 snprintf(directory_path, sizeof(directory_path), "%s%s%s", base_path, date_str,"/"); ensure_directory_exists(directory_path); const char* extension = ".wav";
// 计算所需的总长度(包括null终止符) size_t total_length = strlen(directory_path) + strlen(file_path) + strlen(extension) + 1;
// 动态分配内存来存储完整的文件名 char* filename = (char*)malloc(total_length * sizeof(char)); if (filename == NULL) { perror("malloc failed"); return NULL; // 内存分配失败时返回NULL }
// 使用snprintf来安全地拼接字符串 snprintf(filename, total_length, "%s%s%s", directory_path, file_path, extension);
return filename; } int main(int argc, char* argv[]) { /*解析入口参数*/
/**tts文本*/ const char* tts_txt = argv[1]; printf("ttswenben:"); printf(tts_txt); printf("\n"); /*生成文件存储文件名字*/ const char* file_path=argv[2]; printf(file_path); printf("\n"); /*tts发声参数*/ const char* tts_param=argv[3]; printf(tts_param); printf("\n"); int ret = MSP_SUCCESS; const char* login_params = "appid =8c3c5635, work_dir = .";//登录参数,appid与msc库绑定,请勿随意改动 /* * rdn: 合成音频数字发音方式 * volume: 合成音频的音量 * pitch: 合成音频的音调 * speed: 合成音频对应的语速 * voice_name: 合成发音人 * sample_rate: 合成音频采样率 * text_encoding: 合成文本编码格式 * */
const char* session_begin_params = tts_param; printf(session_begin_params); const char* filename = create_filename(file_path); const char* text = tts_txt; /* 用户登录 */ ret = MSPLogin(NULL, NULL, login_params); //第一个参数是用户名,第二个参数是密码,第三个参数是登录参数,用户名和密码可在http://www.xfyun.cn注册获取 if (MSP_SUCCESS != ret) { printf("MSPLogin failed, error code: %d.\n", ret); MSPLogout(); //退出登录 return 0; } /* 文本合成 */ ret = text_to_speech(text, filename, session_begin_params); if (MSP_SUCCESS != ret) { printf("text_to_speech failed, error code: %d.\n", ret); } MSPLogout(); //退出登录 return 0; } |
更新修改文件
更新完之后,需要进入到/usr/local/tts_server/env/voice/Mydemo/tts_offline_sample 的目录下再次进行
命令如下
source 64bit_make.sh
make
修改完之后 我们可以在/usr/local/tts_server/env/voice/MyDemo/bin 目录下进行测试
命令如下
tts测试 是生成的文字
ewr5we 是命名的wav文件名
./tts_offline_sample "tts测试" ewr5we "engine_type = local,voice_name=xiaoyan, text_encoding = UTF8, tts_res_path = fo|res/tts/xiaoyan.jet;fo|res/tts/common.jet, sample_rate = 16000, speed = 50, volume = 50, pitch = 50, rdn = 2"
执行完之后,可以看到语音文件已经成功生成
以上就是执行的可变参数,但是java调用只能调用Linux的sh脚本,所以我们需要新建一个脚本来供给java进行调用
脚本命令如下
脚本名称为 tts_test.sh |
#!/bin/bash # 定义要source的文件的绝对路径 SOURCE_SCRIPT="/usr/local/tts_server/env/voice/MyDemo/tts_offline_sample/64bit_make.sh" # 定义make命令要执行的目录的绝对路径 MAKE_DIRECTORY="/usr/local/tts_server/env/voice/MyDemo/tts_offline_sample" # 检查source脚本是否存在 if [ ! -f "$SOURCE_SCRIPT" ]; then echo "Error: Source script '$SOURCE_SCRIPT' not found!" exit 1 fi # source该脚本 source "$SOURCE_SCRIPT" # 切换到make命令要执行的目录(如果需要的话) # 注意:如果64bit_make.sh已经设置了必要的环境变量,并且这些变量对make命令有效, # 那么可能不需要下面的cd命令。这取决于64bit_make.sh的具体内容。 # cd "$MAKE_DIRECTORY" # 执行make命令 make -C "$MAKE_DIRECTORY" # 检查make命令的退出状态 if [ $? -ne 0 ]; then echo "Error: Make command failed!" exit 1 fi echo "Make command completed successfully." /usr/local/tts_server/env/voice/MyDemo/bin/tts_offline_sample "$1" $2 "engine_type = local,voice_name=xiaoyan, text_encoding = UTF8, tts_res_path = fo|/usr/local/tts_server/env/voice/MyDemo/bin/msc/res/tts/xiaoyan.jet;fo|/usr/local/tts_server/env/voice/MyDemo/bin/msc/res/tts/common.jet, sample_rate = 16000, speed = 50, volume = 50, pitch = 50, rdn = 2" |
直接上传脚本
由于脚本执行的是绝对路径,所以我们需要修改/usr/local/tts_server/env/voice/Mydemo/tts_offline_sample目录下的64bit_make.sh和Makefile文件下的目录
如果不修改会报如下的错误
修改如图
64bit_make.sh文件修改如图
Makefile文件修改如图
修改完之后 直接进行呼叫测试
成功呼叫
语音文件也成功生成
相关文章:
linux安装部署mysql资料
安装虚拟机 等待检查完成 选择中文 软件选择 网络和主机名 开始安装 设置root密码 ADH-password 创建用户 等待安装完成 重启 接受许可证 Centos 7 64安装完成 安装mysql开始 Putty连接指定服务器 在 opt目录下新建download目录 将mysql文件传到该目录下 查看linux服务器的…...
深入理解 MongoDB:一款灵活高效的 NoSQL 数据库
在现代应用程序开发中,数据存储技术已经从传统的关系型数据库(RDBMS)扩展到多样化的 NoSQL 数据库。MongoDB 作为一款广泛使用的文档型数据库,以其灵活性、高性能和易用性成为开发者的首选之一。本篇博文将从 MongoDB 的核心概念、…...
爆改老旧笔记本---将笔记本改造为家用linux服务器
爆改老旧笔记本---将笔记本改造为家用linux服务器 linux启动盘制作镜像文件分区类型:MBR分区和GPT分区的定义MBR分区(Master Boot Record)GPT分区(GUID Partition Table)应用场景和优势MBR的应用场景和优势GPT的应用场景和优势 Li…...
RocketMQ MQTT Windows10 环境启动
RocketMQ MQTT Windows10 环境启动 参考环境和软件版本下载资源启动RocketMQ启动RocketMQ MQTT 参考 https://blog.csdn.net/weixin_43114058/article/details/140043257 https://blog.csdn.net/yangxiaovip/article/details/138355443 环境和软件版本 操作系统:…...
sd webui整合包怎么安装comfyui
环境: sd webui整合包 comfyui 问题描述: sd webui整合包怎么安装comfyui 扩展安装不成功 解决方案: 1.直接下载 ,解压到SD文件夹里(或者git拉一下) 2.ComfyUI模型共享:如果本机部署过Webui,那么ComfyUI可以与WebUI公用一套模型,防止复制大量模型浪费空间 将…...
Edify 3D: Scalable High-Quality 3D Asset Generation
Deep Imagination Research | NVIDIA 目录 一、Abstract 二、核心内容 1、多视图扩散模型 3、重建模型: 4、数据处理模块: 三、结果 1、文本到 3D 生成结果 2、图像到 3D 生成结果 3、四边形网格拓扑结构 一、Abstract NVIDIA 开发的用于高质量…...
鸿蒙HarmonyOS学习笔记(6)
定义扩展组件样式:Extend装饰器 在前文的示例中,可以使用Styles用于样式的重用,在Styles的基础上,我们提供了Extend,用于扩展原生组件样式。 说明 从API version 9开始,该装饰器支持在ArkTS卡片中使用。 从…...
蓝桥杯备赛笔记(一)
这里的笔记是关于蓝桥杯关键知识点的记录,有别于基础语法,很多内容只要求会用就行,无需深入掌握。 文章目录 前言一、编程基础1.1 C基础格式和版本选择1.2 输入输出cin和cout: 1.3 string以下是字符串的一些简介:字符串…...
在Java中使用Apache POI导入导出Excel(二)
本文将继续介绍POI的使用,上接在Java中使用Apache POI导入导出Excel(一) 使用Apache POI组件操作Excel(二) 14、读取和重写工作簿 try (InputStream inp new FileInputStream("workbook.xls")) { //Inpu…...
linux 中后端jar包启动不起来怎么回事 -bash: java: 未找到命令
一、用以下命令检查jdk版本 输入:java -version,如果JDK 环境变量没有配置,你会看到如下提示 二、配置jdk环境 1.先找到/etc/profile文件,然后在该文件最后面加上以下配置 export JAVA_HOME/usr/local/jdk-21.0.1 export PATH$…...
六大排序算法:插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序
本章讲述数据结构中的六大排序算法 欢迎大佬们踊跃讨论,感谢大家支持! 我的博客主页链接 六大排序算法 一.插入排序1.1 直接插入排序1.2 希尔排序 二.选择排序2.1 单向选择排序2.2双向选择排序2.3 堆排序 三.交换排序3.1 冒泡排序3.2 快速排序3.2.1 Hoa…...
快速排序(C++实现)
基本思想 任取一个元素为中心,所有比它小的元素一律前放,比他大的元素一律后放,形成左右两个子表;对各子表重新选择中心元素并依此规则调整,直到每个子表的元素只剩一个。 通过一趟排序,将待排序记录分割成…...
【数据库知识】数据库关系代数表达式
文章目录 概述一、关系代数表达式的基本组成部分二、关系代数运算符及其使用样例三、关系代数表达式的优化四、总结 概述 数据库关系代数表达式是关系数据库系统查询语言的理论基础,它使用一系列符号和运算符来描述从一个或多个关系(即表)中…...
linux系统清理全部python环境并重装
提问 centos系统清理全部python环境并重装,并且使用宝塔。 解答 要在CentOS系统中彻底清理Python3环境,可以遵循以下步骤: 卸载Python3 使用rpm命令卸载所有与Python3相关的包。这个命令会查询所有已安装的与python3相关的rpm包…...
Servlet的介绍
Servlet是Java Web的核心组件,它是一个运行在服务器端的Java程序,用于接收客户端的请求、处理请求并返回响应。Servlet遵循特定的生命周期,包括初始化、服务、销毁等阶段。 生命周期: init():初始化Servlet实例&#x…...
DICOM医学影像应用篇——伪彩色映射 在DICOM医学影像中的应用详解
目录 引言 伪彩色映射的概念 基本原理 查找表(Look-Up Table, LUT) 步骤 示例映射方案 实现伪彩色映射的C代码 代码详解 伪彩色处理效果展示 总结 扩展知识 LUT 的基本概念 LUT 在伪彩色映射中的应用 示例 引言 在医学影像处理中,…...
(超详细图文详情)Navicat 配置连接 Oracle
1、下载依赖文件 Oracle官网下载直链:https://www.oracle.com/database/technologies/instant-client/winx64-64-downloads.html 夸克网盘下载(oracle19c版本):https://pan.quark.cn/s/5061e690debc 官网下载选择对应 Oracle 版…...
PyTorch:神经网络的基本骨架 nn.Module的使用
神经网络的基本骨架 nn.Module的使用 为了更全面地展示如何使用 nn.Module 构建一个适用于现代图像处理任务的卷积神经网络(CNN),我们将设计一个针对手写数字识别(如MNIST数据集)的简单CNN模型。CNN非常适合处理图像数…...
学习threejs,使用CubeCamera相机创建反光效果
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️CubeCamera 立方体相机 二、…...
Linux网络——IO模型和多路转接
通常所谓的IO,其本质就是等待通信和进行通信,即IO 等 拷贝。 那么想要做到高效的IO,就要在单位时间内,减少“等”的比重。 一.五种IO模型 阻塞 IO: 在内核将数据准备好之前, 系统调用会一直等待. 所有的套接字, 默认都是阻塞方…...
【计网】自定义序列化反序列化(二) —— 实现网络版计算器【上】
🌎 实现网络版计算器【上】 文章目录: 实现网络版计算器【上】 自定义协议 制定自定义协议 Jsoncpp序列化反序列化 Json::Value类 Jsoncpp序列化 Jsoncpp反序列化 自定义协议序列化反序列化 …...
数据结构2:顺序表
目录 1.线性表 2.顺序表 2.1概念及结构 2.2接口实现 1.线性表 线性表是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串 线性表在逻辑上是线性结构,也就说…...
python学习——元组
在 Python 中,元组(tuple)是一种内置的数据类型,用于存储不可变的有序元素集合。以下是关于 Python 元组的一些关键点: 文章目录 定义元组1. 使用圆括号 ()2. 使用 tuple() 函数3. 使用单个元素的元组4. 不使用圆括号…...
apache实现绑定多个虚拟主机访问服务
1个网卡绑定多个ip的命令 ip address add 192.168.45.140/24 dev ens33 ip address add 192.168.45.141/24 dev ens33 在linux服务器上,添加多个站点资料,递归创建三个文件目录 分别在三个文件夹下,建立测试页面 修改apache的配置文件http.…...
无需插件,如何以二维码网址直抵3D互动新世界?
随着Web技术的飞速发展,一个无需额外插件,仅凭二维码或网址即可直接访问的三维互动时代已经悄然来临。这一变革,得益于WebGL技术与先进web3D引擎的完美融合,它们共同构建了51建模网这样一个既便捷又高效的在线三维互动平台&#x…...
系统思考—感恩自己
生命中,真正值得我们铭记与感恩的,不是路途上的苦楚与风雨,而是那个在风雨中依然清醒、勇敢前行的自己,和那些一路同行、相互扶持的伙伴们。 感恩自己,感恩每一个与我们携手并进的人,也期待更多志同道合的…...
Java多线程详解①①(全程干货!!!) 实现简单的线程池 || 定时器 || 简单实现定时器 || 时间轮实现定时器
这里是Themberfue 上一节讲了 线程池 线程池中的拒绝策略 等相关内容 实现简单的线程池 一个线程池最核心的方法就是 submit,通过 submit 提交 Runnable 任务来通知线程池来执行 Runnable 任务 我们简单实现一个特定线程数量的线程池,这些线程应该在…...
DAMODEL丹摩|部署FLUX.1+ComfyUI实战教程
本文仅做测评体验,非广告。 文章目录 1. FLUX.1简介2. 实战2. 1 创建资源2. 1 ComfyUI的部署操作2. 3 部署FLUX.1 3. 测试5. 释放资源4. 结语 1. FLUX.1简介 FLUX.1是由黑森林实验室(Black Forest Labs)开发的开源AI图像生成模型。它拥有12…...
请求(request)
目录 前言 request概述 request的使用 获取前端传递的数据 实例 请求转发 特点 语法 实例 实例1 实例2 【关联实例1】 域对象 组成 作用范围: 生命周期: 使用场景: 使用步骤 存储数据对象 获得数据对象 移除域中的键值…...
关于VNC连接时自动断联的问题
在服务器端打开VNC Server的选项设置对话框,点左边的“Expert”(专家),然后找到“IdleTimeout”,将数值设置为0,点OK关闭对话框。搞定。 注意,服务端有两个vnc服务,这俩都要设置ide timeout为0才行 附件是v…...
网站设计排版怎么做/营销策划书范文案例
2019独角兽企业重金招聘Python工程师标准>>> 使用: npm install echarts* --save 即可实现将最新版本的echarts安装到生产依赖的目的 转载于:https://my.oschina.net/jamesview/blog/1624197...
网站建设一个月做十单/网站入口百度
1 ,启动 zookeeper 命令 :( ) 2 ,查看 zookeeper 启动状态命令 :( ) 3 ,停止 zookeeper 命令 :( ) 4 ,动手题 :请编写老师在课上写的 3 个 shell 脚本,一键启动集群&…...
企业网站升级/国外免费网站建设
题目描述: (1)数组中占比超过一半的元素称之为主要元素。给定一个整数数组,找到它的主要元素。若没有,返回-1。 示例 1: 输入:[1,2,5,9,5,9,5,5,5] 输出:5示例 2: 输入:[3,2] 输出:-…...
wordpress完整迁移/网络营销案例及分析
今日因旅游时间紧张仅通过一道题:1029(本题是IOI98的题目) 今天没有充足时间刷题,明天必会补上转载于:https://www.cnblogs.com/wangximing/p/11094514.html...
网站建设 技术要求/品牌管理
我正在使用Apache-Commons FileUpload库将文件上传到服务器.一切正常,但是突然提交文件时,由于某些原因FileItem.isFormField()返回true.这是我的代码FileUpload.java Servletif (ServletFileUpload.isMultipartContent(request)){List items new ServletFileUpload(new DiskF…...
学校网站的建设费用/百度开户代理
许多外贸公司在选择邮箱时,单次群发量和邮箱容量都是客户选择邮箱品牌的必要条件。小编了解到一些做外贸的公司是需要跟海外的客户发邮件业务往来的,所以,他们需要单次群发量非常高,目前小编了解到,还有一些外贸公司的…...