C++ 网络编程项目fastDFS分布式文件系统(九)总结

1. Location语法

1. 语法规则

        

location [= |~|~ * |^~ ] /uri/
{
}
正则表达式中的特殊字符 :
- . () {} [] * + ?
2. Location 优先级说明
nginx location 和配置中 location 的顺序没有太大关系。
location 表达式的类型有关。
相同类型的表达式,字符串长的会优先匹配

 

3. location 表达式类型
~ 表示执行一个正则匹配,区分大小写
~* 表示执行一个正则匹配,不区分大小写
^~ 表示普通字符匹配。使用前缀匹配。如果匹配成功,则不再匹配其他 location
= 进行普通字符精确匹配。也就是完全匹配
4. 匹配模式及优先级顺序 ( -> ):

 

客户端 : http ://localhost/helloworld/test/a. html
客户端 : http ://localhost/helloworld/test/
/helloworld/test/a. html
/helloworld/test/
location /
{
}
location /helloworld/
{
}
location /helloworld/test/
{
}
location =/helloworld/test/
{
root xxx;
}
http ://localhost/helloworld/test/a. html
location ^~ /helloworld/test/
{
}
location ^~ /login/
{
}
http ://localhost/helloworld/test/a. JPG
location ~ * \ .[ jpg|png ]
{
}
http ://192.168.1.100/login/hello/world/login. html
/login/hello/world/login. html
location /
{
}
location /login/
{
}
location /login/hello/
{
}
location /login/hello/world/
{
}
location ~ /group[ 1-9 ]/M0[ 0-9 ]
{
}

练习: 

 

匹配示例 :
/ -> configuration
/index.html -> configuration
/documents/document.html -> configuration C
/documents/
/
/images/1.gif -> configuration D
/images/
/
/documents/1.jpg -> configuration E

2. 项目总结

         

 

1. 客户端
        Qt
        了解了Qt http 通信
2. nginx 反向代理服务器
        为web 服务器服务
                web服务器需要集群
3. web 服务器 - nginx
        处理静态请求 - > 访问服务器文件
        动态请求 -> 客户端给服务器提交的数据
        借助fastCGI 进行处理
        讲的是单线程处理方式 - API
                也可以多线程处理 -> 另外的 API
                使用spawn-fcgi启动
4. mysql
        关系型数据库 - 服务器端
        存储什么?
                项目中所有用到的数据
5. redis
非关系型数据库 - 服务器端使用
        数据默认在内存, 不需要 sql 语句 , 不需要数据库表
                键值对存储, 操作数据使用的是命令
                和关系型数据库配合使用
                存储服务器端经常访问的数据
6. fastDFS
分布式文件系统
        追踪器, 存储节点 , 客户端
                存储节点的集群
                横向扩容 -> 增加容量
                添加新组, 将新主机放到该组中
                纵向扩容 -> 备份
                将主机放到已经存在的组中
                存储用户上传的所有的文件
                给用户提供下载服务器

3. 项目提炼

1. 做的是文件服务器
                电商网站
                旅游网站
                租房
                装修公司
                医院
                短视频网站
2. 需要什么 ?
        首先需要的是fastDFS
        配置环境
        扩容
        操作fastDFS - 客户端
        web
        桌面终端 - Qt
数据库操作
        mysql
        oralce
有一个web 服务器 - Nginx
        静态资源部署
        动态请求 - 编写 fastCGI 程序
                注册
                登录
                上传
                下载
                秒传
                文件列表的获取
redis
存储服务器访问比较频繁的数据

4. 存储节点反向代理

http://192.168.31.109:80/group1/M00/00/00/wKgfbViy2Z2AJ-FTAaM3As g3Z0782.mp4"
http://192.168.31.109:80/group2/M00/00/00/wKgfbViy2Z2AJ-FTAaM3As g3Z0782.mp4"

 

上图的反向代理服务器代理的是每个存储节点上部署的 Nginx
- 每个存储节点上的 Nginx 的职责 : 解析用户的 http 请求 , 帮助用户快速下载文件
客户端上传了一个文件 , 被存储到了 fastDFS , 得到一个文件 ID
/group1/M00/00/00/ wKgfbViy2Z2AJ-FTAaM3Asg3Z0782 . mp4"
因为存储节点有若干个 , 所有下载的时候不知道对应的存储节点的访问地址
给存储节点上的 nginx web 服务器添加反向代理服务器之后 , 下载的访问地址 :
- 只需要知道 nginx 反向代理服务器的地址就可以了 : 192.168.31. 109
- 访问的 url :
http ://192.168.31.109/group1/M00/00/00/ wKgfbViy2Z2AJ-FTAaM3Asg3Z0782 . mp4
客户端的请求发送给了 nginx 反向代理服务器
- 反向代理服务器不处理请求 , 只转发 , 转发给存储节点上的 nginx 服务器
反向代理服务器的配置 - nginx. conf
- 找出处理指令 : 去掉协议 , iP/ 域名 , 末尾文件名 , ? 和后边的字符串
- /group1/M00/00/00/ - 完整的处理指令
- 添加 location
server {
location /group1/ M00
{
# 数据转发 , 设置转发地址
proxy_pass http ://test.com;
}
location /group2/ M00
{
# 数据转发 , 设置转发地址
proxy_pass http ://test1.com;
}
}
upstream test. com
{
# fastDFS 存储节点的地址 , 因为存储节点上安装了 nginx, 安装的 nginx 作为 web 服务器的角色
server 192.168.31.100;
server 192.168.31.101;
server 192.168.31.102;
}
upstream test1. com
{
# fastDFS 存储节点的地址 , 因为存储节点上安装了 nginx, 安装的 nginx 作为 web 服务器的角色
server 192.168.32.100;
server 192.168.33.101;
server 192.168.34.102;
}
# ===================================
存储节点上的 web 服务器的配置
存储节点 1
location /group1/ M00
{
# 请求处理
root 请求的资源的根目录 ; // 存储节点的 store_path0 对应的路径 + data
ngx_fastdfs_module;
}
location /group1/ M01
{
# 请求处理
root 请求的资源的根目录 ;
ngx_fastdfs_module;
}
存储节点 2
location /group2/ M00
{
# 请求处理
root 请求的资源的根目录 ;
ngx_fastdfs_module;
}
location /group2/ M01
{
# 请求处理
root 请求的资源的根目录 ;
ngx_fastdfs_module;
}
存储节点 3
location /group3/ M00
{
# 请求处理
root 请求的资源的根目录 ;
ngx_fastdfs_module;
}
location /group3/ M01
{
# 请求处理
root 请求的资源的根目录 ;
ngx_fastdfs_module;
}

5. https

         

 

1. 在百度服务器端首先生成一个秘钥对 -> 对公钥分发
2. 百度将公钥给到了 CA 认证机构 , ca 对私钥进行签名 -> 生成了证书 .
3. 第一步第二部只做一次
4. 客户端访问百度 , 百度将 ca 生成的证书发送给客户端
5. 浏览器对收到的证书进行认证
6. 如果证书没有问题 -> 使用 ca 的公钥将服务器的公钥从证书中取出
7. 我们得到了百度的公钥
8. 在浏览器端生成一个随机数 , 使用得到的公钥进行加密 , 发送给服务器
9. 服务器端使用私钥解密 , 得到了随机数 , 这个随机数就是对称加密的秘钥
10. 现在秘钥分发已经完成 , 后边的通信使用的的对称加密的方式
1. 对称加密
加解密秘钥是同一个
2. 非对称加密
公钥 , 私钥
rsa -> 公钥私钥都是两个数字
ecc -> 椭圆曲线 , 两个点
公钥加密 , 私钥解密
数据传输的时候使用
私钥加密 , 公钥解密
数字签名
3. 哈希函数
md5/ sha1/sha2
得到散列值 , 散列值是定长的
4. 消息认证码
生成消息认证码 : ( 将原始数据 + 共享秘钥 ) * 进行哈希运算 = 散列值
验证消息认证码 :
( 接收的原始数据 + 共享秘钥 ) * 哈希运算 = 新的散列值
新散列值和旧散列值进行比较 , 看是不是相同
作用 :
验证数据的一致性型
弊端 :
两端共享秘钥必须相同 , 共享秘钥分发困难
5. 数字签名 -> 目的告诉所有人这个数据的所有者是 xxx, xxx 就是拿私钥的人
生成一个非对称加密的密钥对
公钥
私钥
生成签名 :
对原始数据进行哈希运算 -> 散列值
使用非对称加密的私钥 , 对散列值进行签名 ( 私钥加密 ) -> 密文
得到的密文就是数字签名
签名的校验 :
校验这会收到签名者发送的数据
原始数据
数字签名
对接收的数据进行哈希运算 -> 散列值
使用非对称加密的公钥 , 对数字签名进行解密 -> 明文 == 签名者生成的散列值
校验者的散列值 和 签名者的散列值进行比较
相同 -> 校验成功了 , 数据属于签名的人
失败 -> 数据不属于签名的人
弊端 :
接收公钥的人没有办法校验公钥的所有者。

6. 证书
由一个受信赖的机构 (CA) 对某人的公钥进行数字签名
CA 有一个密钥对
使用 ca 的私钥对某个人的公钥进行加密 -> 证书
这个人 的公钥
这个人的个人信息

 

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

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

相关文章

K8S最新版本集群部署(v1.28) + 容器引擎Docker部署(上)

温故知新 📚第一章 前言📗背景📗目的📗总体方向 📚第二章 基本环境信息📗机器信息📗软件信息📗部署用户kubernetes 📚第三章 Kubernetes各组件部署📗安装kube…

BlazorServer中C#与JavaScript的相互调用

BlazorServer中C#与JavaScript的相互调用 前言: ​ 虽然BlazorServer中推荐使用C#在razor页面中的替代JavaScript来完成逻辑的编写,但当需要使用第三方的javascript文件/组件里的内容时,则难免要在C#中调用其方法或对象。反之当你的(用到第…

Java:HashMap、LinkedHashMap、TreeMap集合的底层原理和集合的嵌套

HashMap的底层原理 LinkedHashMap的底层原理 TreeMap集合的底层原理 集合的嵌套

Elasticsearch 8.X reindex 源码剖析及提速指南

1、reindex 源码在线地址 为方便大家验证,这里给出 reindex github 源码地址。 https://github.com/elastic/elasticsearch/blob/001fcfb931454d760dbccff9f4d1b8d113f8708c/server/src/main/java/org/elasticsearch/index/reindex/ReindexRequest.java reindex 常见…

IDEA对Web和Tomcat的一些配置

这里只是做了自己学习中的一点记录,仅供参考哈! 配置Tomcat Modules新增Web 新增module后新增Artifacts 新增Artifacts后Tomcat新增布署 将指定的module由普通java项目变成web项目 直接创建布署到Tomcat时所需要的Aritifacts包 配置Servlet的依赖包 配置…

Vue2学习笔记の使用Vue脚手架

目录 使用Vue脚手架脚手架文件结构关于不同版本的Vuevue.config.js配置文件ref属性props配置项mixin(混入)插件scoped样式总结TodoList案例webStorage组件的自定义事件全局事件总线(GlobalEventBus)消息订阅与发布(pubsub)nextTic…

redis windows 版本安装

1. 下载windows安装包并解压 如果是Linux版本可以直接到官网下载,自3.x起官网和微软网站就没有redis安装包更新了,好在github有开发者在编译发布更新(目前最新有5.0.9版本可下),地址:redis windows 5版本下…

Maven 基础之安装和命令行使用

Maven 的安装和命令行使用 1. 下载安装 下载解压 maven 压缩包(http://maven.apache.org/) 配置环境变量 前提:需要安装 java 。 在命令行执行如下命令: mvn --version如出现类似如下结果,则证明 maven 安装正确…

MyBatisPlus实现多租户功能

前言:多租户是一种软件架构技术,在多用户的环境下,共有同一套系统,并且要注意数据之间的隔离性。 一、SaaS多租户简介 1.1、SaaS多租户 SaaS,是Software-as-a-Service的缩写名称,意思为软件即服务&#x…

HTML之VSCode简单配置与创建

目录 插件下载 然后输入源码&#xff1a; 使用 效果 插件下载 下载这个插件后可以直接运行&#xff1a; 然后创建一个文件&#xff1a; 然后输入源码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"…

Redis 10 大数据类型

1. which 10 1. redis字符串 2. redis 列表 3. redis哈希表 4. redis集合 5. redis有序集合 6. redis地理空间 7. redis基数统计 8. redis位图 9. redis位域 10. redis流 2. 获取redis常见操作指令 官网英文&#xff1a;https://redis.io/commands 官网中文&#xff1a;https:/…

9.3 功率放大电路的安全运行

在功率放大电路中&#xff0c;功放管既要流过大电流&#xff0c;又要承受高电压。例如&#xff0c;在 OCL 电路中&#xff0c;只有功放管满足式&#xff08;9.2.13&#xff09;所示极限值的要求&#xff0c;电路才能正常工作。因此&#xff0c;所谓功率放大电路的安全运行&…

【VS Code插件开发】状态栏(五)

&#x1f431; 个人主页&#xff1a;不叫猫先生&#xff0c;公众号&#xff1a;前端舵手 &#x1f64b;‍♂️ 作者简介&#xff1a;前端领域优质作者、阿里云专家博主&#xff0c;共同学习共同进步&#xff0c;一起加油呀&#xff01; &#x1f4e2; 资料领取&#xff1a;前端…

java八股文面试[多线程]——死锁、活锁、饥饿

DCL双重锁&#xff1a;TODO 如何预防死锁&#xff1a; 如何查看线程死锁&#xff1a; 知识来源&#xff1a; 【2023年面试】描述一下线程安全活跃态问题&#xff0c;以及竞态条件_哔哩哔哩_bilibili 【2023年面试】如何预防死锁_哔哩哔哩_bilibili 【并发与线程】阿里一面&…

【leetcode 力扣刷题】双指针//哈希表 解决链表有环等问题

双指针//哈希表 解决链表有环等问题 19. 删除链表的倒数第N个结点遍历两次&#xff0c;先求得链表长度&#xff0c;再删除双指针&#xff0c;只遍历一次 141. 环形链表 【判断链表是否有环】哈希表快慢双指针 142. 环形链表Ⅱ 【找环的入口】哈希表双指针求环中有多少个结点 面…

IDEA使用git

文章目录 给所有文件配置git初始化本地仓库创建.gitignore文件添加远程仓库分支操作 给所有文件配置git 初始化本地仓库 创建.gitignore文件 添加远程仓库 分支操作 新建分支 newbranch 切换分支 checkout 推送分支 push 合并分支 merge

openGauss学习笔记-48 openGauss 高级数据管理-函数

文章目录 openGauss学习笔记-48 openGauss 高级数据管理-函数48.1 数学函数48.2 三角函数列表48.3 字符串函数和操作符48.4 类型转换相关函数 openGauss学习笔记-48 openGauss 高级数据管理-函数 openGauss常用的函数如下&#xff1a; 48.1 数学函数 abs(x) 描述&#xff1a;…

SpringBootWeb案例 Part 4

3. 修改员工 需求&#xff1a;修改员工信息 在进行修改员工信息的时候&#xff0c;我们首先先要根据员工的ID查询员工的信息用于页面回显展示&#xff0c;然后用户修改员工数据之后&#xff0c;点击保存按钮&#xff0c;就可以将修改的数据提交到服务端&#xff0c;保存到数据…

【CP2K学习】-在Ubuntu上安装CP2K的全过程(包括gcc,gfortran,MKL等配置)

在Ubuntu中安装CP2K CP2K的安装检查系统是否安装gcc,gfortranMKL数学库的安装CP2K安装包下载CP2K的编译CP2K的测试ssmp版本测试popt版本测试 CP2K是第一性原理计算程序中发展迅速的程序之一&#xff0c;因其开源性、速度性等优点&#xff0c;是广大计算化学研究者的选择。 本文…

数据通信——传输层(UDP)

引言 我们上网观看比赛的时候&#xff0c;一旦网络信号出现问题&#xff0c;那可就太难受了&#xff0c;这意味着卡顿的时间内&#xff0c;你会错过这段时间内的内容。这种特性要归功于UDP&#xff08;User Datagram Protocol&#xff09;用户数据报协议。 无连接性 一般的&am…