- Docker:快速搭建 RabbitMQ 集群的技术指南
拾荒的小海螺
DevOpsdockerrabbitmq容器
1、简述RabbitMQ是目前最流行的开源消息中间件之一,广泛应用于解耦、异步通信、削峰填谷等场景。本篇博客将带你通过Docker快速搭建RabbitMQ集群,并展示SpringBoot集成的实践案例,助你高效入门RabbitMQ分布式消息系统。样例代码:https://gitee.com/lhdxhl/springboot-example.git2、搭建2.1准备工作首先安装Docker和Doc
- Leetcode 423. Reconstruct Original Digits from English
小白菜又菜
Leetcode解题报告leetcodelinux算法
ProblemGivenastringscontaininganout-of-orderEnglishrepresentationofdigits0-9,returnthedigitsinascendingorder.AlgorithmCounttheoccurrencesofcharactersbasedonuniqueletters—forexample,theletter‘z’onlyapp
- 【如何设置ssh免密登录】
岁月玲珑
linuxsshgithubgit
设置SSH免密登录能够让你在不输入密码的情况下,通过SSH协议安全登录远程服务器。下面为你详细介绍设置步骤:1.生成SSH密钥对(若未生成)要生成SSH密钥对,可在本地终端执行以下命令:ssh-keygen-trsa-b4096-C"
[email protected]"当系统提示你“Enterafileinwhichtosavethekey”时,你可以直接按回车键使用默认文件位置,也可以
- DDD 分层架构实战指南:从项目结构到落地挑战
一、项目结构详解(以电商订单系统为例)src/main/java├──com.example│├──common#通用工具类、基础异常、常量│├──order#订单限界上下文(模块示例)││├──interfaces#用户接口层│││├──controller#HTTP/RESTAPI│││├──rpc#Dubbo/gRPC接口│││└──consumer#消息队列消费者(如Kafka监听)││├
- 『大模型笔记』KV缓存:Transformer中的内存使用!
AI大模型前沿研究
大模型笔记缓存transformerKVcache大模型LLM
『大模型笔记』KV缓存:Transformer中的内存使用!文章目录一.KV缓存:Transformer中的内存使用!1.1.介绍1.2.自注意力机制回顾1.3.KV缓存的工作原理1.4.内存使用和示例1.4.1.存储键值缓存需要多少内存1.4.2.Example:OPT-30B(300亿参数)四.参考文献进一步阅读:加速GPT-KV缓存:https://www.dipkumar.dev/beco
- Milvus知识库创建
importconfigparserimporttimeimportrandomfrompymilvusimportMilvusClientfrompymilvusimportDataTypecfp=configparser.RawConfigParser()cfp.read('config.ini')milvus_uri=cfp.get('example','uri')token=cfp.get
- LD_TRACE_LOADED_OBJECTS
想和我重名?
小Tipslinux
LD_TRACE_LOADED_OBJECTSExample:LD_TRACE_LOADED_OBJECTS=1$(可执行程序)#LD_TRACE_LOADED_OBJECTS=1/bin/busyboxlibc.so.0=>/lib//libc.so.0(0xb6f3c000)ld-uClibc.so.1=>/lib/ld-uClibc.so.0(0xb6fc8000)#LD_TRACE_LOA
- Django REST framework - 渲染器
djangopython
渲染器的确定方式视图的有效渲染器集合始终被定义为一个类列表。当进入视图时,RESTframework会在传入请求上执行内容协商,确定最合适的渲染器以满足请求。内容协商的基本过程涉及检查请求的Accept头,以确定其期望在响应中接收的媒体类型。另外,也可以使用URL上的格式后缀来显式请求特定的表示形式,例如,URLhttp://example.com/api/users_count.json可能是一
- Django REST framework - 格式后缀
djangopython
URLconf中的格式后缀模式为WebAPI使用URL文件扩展名以提供特定媒体类型端点是一种常见模式。例如,使用'http://example.com/api/users.json'提供JSON格式的表示。若在API的URLconf每个条目中添加格式后缀模式,容易出错且违背DRY原则,因此RESTframework提供了一个快捷方式,用于将这些模式添加到URLConf中。format_suffix
- 结构体字段能否单独加 mut
穗余
Rustjava服务器数据库
你问的这个问题在Rust里很常见:一、结构体字段能否单独加mut1.结构体字段能否单独加mut?不能。Rust中,mut是用来修饰变量绑定的,可变性是绑定的属性,而不是结构体字段本身的属性。你不能写:letuser1=User{mutusername:String::from("user1"),//❌语法错误email:String::from("
[email protected]"),sign_
- playwright模块
qq_41119282
pythonplayrightUI自动化前端javascripthtml自动化
简写click()page.click("//input[@type='submit']")fill()page.locator("input[name=\"login_code\"]").fill("4121")page.fill("input[name=\'login_code\']","4121")等待元素.wait_for()page.locator("text=exampledomain
- URL带有中文会引入哪些问题
依旧风轻
Swift才是未来SQIiOSSwiftUnicodeURL
处理含中文字符的URL1为什么会出现“乱码”或崩溃?URL标准(RFC3986)规定:除少数保留字符外,URL只能包含ASCII。中文属于Unicode,因此必须先转换。如果直接把https://example.com/路径/这样的字符串传给URL(string:),Swift会把它视为非法,初始化直接返回nil,后续网络请求也会失败。主机名部分(如网址.中国)可以使用IDN(Punycode)隐
- 代理模式 - Flutter中的智能替身,掌控对象访问的每一道关卡!
明似水
flutter代理模式flutter
痛点场景:直接加载高清大图假设你的应用需要显示用户相册:NetworkImage('https://example.com/high-res-photo.jpg')面临的问题:网络差时长时间白屏重复下载相同图片浪费流量敏感图片无权限验证内存占用过高导致崩溃代理模式解决方案核心思想:为其他对象提供一种代理以控制对这个对象的访问。三种常见代理类型:虚拟代理:延迟加载大资源(如占位图→高清图)保护代理:
- acme自签证书
获取acme自签证书1、安装安装acmegitclonehttps://gitee.com/neilpang/acme.sh.gitcdacme.sh./
[email protected]、获取阿里云ak/sk3、生成证书通过环境变量导入ak/skexportAli_Key="控制台获取ak"exportAli_Secret="控制台获取sk"生成证书(有效期3个月
- (PAT甲级)1019 General Palindromic Number 进制转换+回文数 (进制转换问题的实用技巧)
JaredYe
算法c++c语言pat考试
AnumberthatwillbethesamewhenitiswrittenforwardsorbackwardsisknownasaPalindromicNumber.Forexample,1234321isapalindromicnumber.Allsingledigitnumbersarepalindromicnumbers.Althoughpalindromicnumbersaremos
- 《凤凰架构》C7-分布式服务
Epi_HHH
阅读笔记java
目录一、服务发现二、网关路由三、负载均衡一、服务发现服务发现就是动态定位服务实例地址,解决分布式环境下服务实例IP和端口可能变化的问题1)基础概念远程服务调用精确坐标:全限定名+端口号+服务标识,如:order-service.default.svc.cluster.local:50051/com.example.order.OrderService/getOrderById服务标识:与具体的应用
- React用户交互事件
在React中处理用户交互事件(如点击、输入、提交等)的方式与原生JavaScript类似,但有一些语法差异和最佳实践。以下是常见交互事件的处理方法及代码示例:一、基本事件处理(点击、输入等)1.点击事件(onClick)importReact,{useState}from'react';constButtonExample=()=>{const[count,setCount]=useState(
- url_luacher适配指南
harmonyos
ohos平台适配flutter三方库指导url_launcher1.准备工作下载待适配的三方插件:官方插件库本指导书,以适配url_launcher6.3.1为例2.插件目录lib:是对接dart端代码的入口,由此文件接收到参数后,通过channel将数据发送到原生端;android:安卓端代码实现目录;ios:ios原生端实现目录;example:一个依赖于该插件的Flutter应用程序,来说明
- 雅思英语----写作观点表达(一)
dulu~dulu
雅思雅思英语笔记雅思英语写作雅思写作话题
目录(1)犯罪话题(2)压力的来源(3)人口老龄化(4)接受教育(5)房屋问题1.保护老建筑2.住房紧缺雅思写作观点用在核心段的逻辑:观点表述+举例:Itisevidentthatlivingasimplelifemakesgreatcontributionstocombatingenvironmentalchallenges.Forexample,ifpeoplechoosetospendhol
- 微服务架构设计模式资源下载介绍:掌握微服务设计精髓,助力架构升级
微服务架构设计模式资源下载介绍:掌握微服务设计精髓,助力架构升级【下载地址】微服务架构设计模式资源下载介绍探索微服务架构的奥秘,掌握设计模式的精髓。本仓库提供了一本权威的英文书籍《MicroservicePatterns:WithexamplesinJava》的PDF资源,由克里斯-理查森精心撰写。书中不仅涵盖了微服务的基本概念,还深入探讨了服务拆分、服务发现、负载均衡等关键主题,辅以丰富的实例和
- 用Tensorflow进行线性回归和逻辑回归(十)
lishaoan77
tensorflow线性回归tensorboard可视化
用TensorBoard可视化线性回归模型TensorBoard是一种可视化工具,用于了解、调试和优化模型训练过程。它使用在执行程序时编写的摘要事件。上面定义的模型使用tf.summary.FileWriter来写日志到日志目录/tmp/lr-train.我们可以用命令调用日志目录的TensorBoard,见Example3-13(TensorBoard已黙认安装与TensorFlow一起).Ex
- Git使用基本指南
LEIX_lll
git
一、Git基础配置首先需要配置用户信息,让Git知道你是谁:gitconfig--globaluser.name"你的名字"gitconfig--globaluser.email"你的邮箱@example.com"如果需要查看配置信息,可以使用:gitconfig--list二、仓库操作1.创建新仓库gitinit该命令会在当前目录下创建一个新的Git仓库。2.克隆已有仓库gitclone[远程仓
- Dpdk环境的搭建
Flying Fish(HHH)
dpdk分布式计算机网络
1、下载源码:gitclonehttps://github.com/DPDK/dpdk2、编译命令CC=gccmeson-Dlibdir=lib--default-library=static-Dexamples=allx86_64-native-linuxapp-gcc-Dbuildtype=debugoptimizedninja-Cx86_64-native-linuxapp-gcc-j110
- golang入门
弱冠少年
gogolang开发语言后端
主要参考资料:如果重新开始,我会怎么学go:https://www.bilibili.com/video/BV1PhtPejEdT/?spm_id_from=333.337.search-card.all.click&vd_source=ef5b6d43cf1d4ed823db3e9133e97d2dgobyexample:https://gobyexample.com/gowebbyexampl
- 为什么Cloudflare免费版更适合个人用户?
群联云防护小杜
安全问题汇总网络服务器自动化运维人工智能
#实战:Cloudflare免费版WAF规则绕过演示importrequeststarget_url="https://example.com/login"#替换为CF防护的站点headers={"User-Agent":"Mozilla/5.0(compatible;EvilBot/1.0)","X-Forwarded-For":"1.1.1.1,2.2.2.2,3.3.3.3"#伪造IP链}#
- git命令
半糖1122
git
掌握这20个Git命令,成为团队协作高手!基础配置命令1配置用户信息是使用Git的第一步:#配置全局用户名和邮箱gitconfig--globaluser.name"FedJavaScript"gitconfig--globaluser.email"
[email protected]"#查看配置信息gitconfig--list2.仓库初始化创建新的Git仓库:#初始化新仓库git
- spring-webmvc @RequestBody 典型用法
张紫娃
注解springwindowsjava
典型用法接收JSON请求体并转换为Java对象@PostMapping("/users")publicStringcreateUser(@RequestBodyUseruser){return"Usercreated:"+user.getName();}//客户端请求示例(JSON):{"name":"Alice","email":"
[email protected]"}//Spring自动使用H
- Spring Boot 3.x 项目搭建 (一)
不愿意透露姓名的樊同学
javaspringbootlog4j后端
以下是一个基础SpringBoot项目的创建指南,整合了官方推荐方式和实用配置,帮助您快速搭建可运行的项目骨架。一、项目创建方式1.在线工具SpringInitializr(推荐)步骤:访问SpringInitializr。配置参数:Project:Maven/Gradle(选Maven更通用)Language:JavaSpringBoot:最新稳定版(如3.x)Group:com.example
- Traefik和Spring Cloud Gateway接口级限流和熔断对比
老兵发新帖
云原生
接口级限流和熔断对比特性TraefikSpringCloudGateway接口级限流✅支持,但配置复杂✅原生支持,灵活接口级熔断✅支持,但配置复杂✅原生支持,灵活配置方式多个IngressRoute编程式+配置式灵活性中等高维护成本高(配置文件多)中等(代码维护)Traefik接口级实现当前项目状态(服务级):#您当前的配置-服务级别-match:Host(`example.com`)&&Path
- 使用 Python 的 requests 库实现流式输出
liangblog
拿来就用系列python开发语言
使用Python的requests库实现流式输出importrequestsurl='https://api.example.com/stream'#替换为实际的APIURLwithrequests.get(url,stream=True)asr:r.raise_for_status(
- SAX解析xml文件
小猪猪08
xml
1.创建SAXParserFactory实例
2.通过SAXParserFactory对象获取SAXParser实例
3.创建一个类SAXParserHander继续DefaultHandler,并且实例化这个类
4.SAXParser实例的parse来获取文件
public static void main(String[] args) {
//
- 为什么mysql里的ibdata1文件不断的增长?
brotherlamp
linuxlinux运维linux资料linux视频linux运维自学
我们在 Percona 支持栏目经常收到关于 MySQL 的 ibdata1 文件的这个问题。
当监控服务器发送一个关于 MySQL 服务器存储的报警时,恐慌就开始了 —— 就是说磁盘快要满了。
一番调查后你意识到大多数地盘空间被 InnoDB 的共享表空间 ibdata1 使用。而你已经启用了 innodbfileper_table,所以问题是:
ibdata1存了什么?
当你启用了 i
- Quartz-quartz.properties配置
eksliang
quartz
其实Quartz JAR文件的org.quartz包下就包含了一个quartz.properties属性配置文件并提供了默认设置。如果需要调整默认配置,可以在类路径下建立一个新的quartz.properties,它将自动被Quartz加载并覆盖默认的设置。
下面是这些默认值的解释
#-----集群的配置
org.quartz.scheduler.instanceName =
- informatica session的使用
18289753290
workflowsessionlogInformatica
如果希望workflow存储最近20次的log,在session里的Config Object设置,log options做配置,save session log :sessions run ;savesessio log for these runs:20
session下面的source 里面有个tracing 
- Scrapy抓取网页时出现CRC check failed 0x471e6e9a != 0x7c07b839L的错误
酷的飞上天空
scrapy
Scrapy版本0.14.4
出现问题现象:
ERROR: Error downloading <GET http://xxxxx CRC check failed
解决方法
1.设置网络请求时的header中的属性'Accept-Encoding': '*;q=0'
明确表示不支持任何形式的压缩格式,避免程序的解压
- java Swing小集锦
永夜-极光
java swing
1.关闭窗体弹出确认对话框
1.1 this.setDefaultCloseOperation (JFrame.DO_NOTHING_ON_CLOSE);
1.2
this.addWindowListener (
new WindowAdapter () {
public void windo
- 强制删除.svn文件夹
随便小屋
java
在windows上,从别处复制的项目中可能带有.svn文件夹,手动删除太麻烦,并且每个文件夹下都有。所以写了个程序进行删除。因为.svn文件夹在windows上是只读的,所以用File中的delete()和deleteOnExist()方法都不能将其删除,所以只能采用windows命令方式进行删除
- GET和POST有什么区别?及为什么网上的多数答案都是错的。
aijuans
get post
如果有人问你,GET和POST,有什么区别?你会如何回答? 我的经历
前几天有人问我这个问题。我说GET是用于获取数据的,POST,一般用于将数据发给服务器之用。
这个答案好像并不是他想要的。于是他继续追问有没有别的区别?我说这就是个名字而已,如果服务器支持,他完全可以把G
- 谈谈新浪微博背后的那些算法
aoyouzi
谈谈新浪微博背后的那些算法
本文对微博中常见的问题的对应算法进行了简单的介绍,在实际应用中的算法比介绍的要复杂的多。当然,本文覆盖的主题并不全,比如好友推荐、热点跟踪等就没有涉及到。但古人云“窥一斑而见全豹”,希望本文的介绍能帮助大家更好的理解微博这样的社交网络应用。
微博是一个很多人都在用的社交应用。天天刷微博的人每天都会进行着这样几个操作:原创、转发、回复、阅读、关注、@等。其中,前四个是针对短博文,最后的关注和@则针
- Connection reset 连接被重置的解决方法
百合不是茶
java字符流连接被重置
流是java的核心部分,,昨天在做android服务器连接服务器的时候出了问题,就将代码放到java中执行,结果还是一样连接被重置
被重置的代码如下;
客户端代码;
package 通信软件服务器;
import java.io.BufferedWriter;
import java.io.OutputStream;
import java.io.O
- web.xml配置详解之filter
bijian1013
javaweb.xmlfilter
一.定义
<filter>
<filter-name>encodingfilter</filter-name>
<filter-class>com.my.app.EncodingFilter</filter-class>
<init-param>
<param-name>encoding<
- Heritrix
Bill_chen
多线程xml算法制造配置管理
作为纯Java语言开发的、功能强大的网络爬虫Heritrix,其功能极其强大,且扩展性良好,深受热爱搜索技术的盆友们的喜爱,但它配置较为复杂,且源码不好理解,最近又使劲看了下,结合自己的学习和理解,跟大家分享Heritrix的点点滴滴。
Heritrix的下载(http://sourceforge.net/projects/archive-crawler/)安装、配置,就不罗嗦了,可以自己找找资
- 【Zookeeper】FAQ
bit1129
zookeeper
1.脱离IDE,运行简单的Java客户端程序
#ZkClient是简单的Zookeeper~$ java -cp "./:zookeeper-3.4.6.jar:./lib/*" ZKClient
1. Zookeeper是的Watcher回调是同步操作,需要添加异步处理的代码
2. 如果Zookeeper集群跨越多个机房,那么Leader/
- The user specified as a definer ('aaa'@'localhost') does not exist
白糖_
localhost
今天遇到一个客户BUG,当前的jdbc连接用户是root,然后部分删除操作都会报下面这个错误:The user specified as a definer ('aaa'@'localhost') does not exist
最后找原因发现删除操作做了触发器,而触发器里面有这样一句
/*!50017 DEFINER = ''aaa@'localhost' */
原来最初
- javascript中showModelDialog刷新父页面
bozch
JavaScript刷新父页面showModalDialog
在页面中使用showModalDialog打开模式子页面窗口的时候,如果想在子页面中操作父页面中的某个节点,可以通过如下的进行:
window.showModalDialog('url',self,‘status...’); // 首先中间参数使用self
在子页面使用w
- 编程之美-买书折扣
bylijinnan
编程之美
import java.util.Arrays;
public class BookDiscount {
/**编程之美 买书折扣
书上的贪心算法的分析很有意思,我看了半天看不懂,结果作者说,贪心算法在这个问题上是不适用的。。
下面用动态规划实现。
哈利波特这本书一共有五卷,每卷都是8欧元,如果读者一次购买不同的两卷可扣除5%的折扣,三卷10%,四卷20%,五卷
- 关于struts2.3.4项目跨站执行脚本以及远程执行漏洞修复概要
chenbowen00
strutsWEB安全
因为近期负责的几个银行系统软件,需要交付客户,因此客户专门请了安全公司对系统进行了安全评测,结果发现了诸如跨站执行脚本,远程执行漏洞以及弱口令等问题。
下面记录下本次解决的过程以便后续
1、首先从最简单的开始处理,服务器的弱口令问题,首先根据安全工具提供的测试描述中发现应用服务器中存在一个匿名用户,默认是不需要密码的,经过分析发现服务器使用了FTP协议,
而使用ftp协议默认会产生一个匿名用
- [电力与暖气]煤炭燃烧与电力加温
comsci
在宇宙中,用贝塔射线观测地球某个部分,看上去,好像一个个马蜂窝,又像珊瑚礁一样,原来是某个国家的采煤区.....
不过,这个采煤区的煤炭看来是要用完了.....那么依赖将起燃烧并取暖的城市,在极度严寒的季节中...该怎么办呢?
&nbs
- oracle O7_DICTIONARY_ACCESSIBILITY参数
daizj
oracle
O7_DICTIONARY_ACCESSIBILITY参数控制对数据字典的访问.设置为true,如果用户被授予了如select any table等any table权限,用户即使不是dba或sysdba用户也可以访问数据字典.在9i及以上版本默认为false,8i及以前版本默认为true.如果设置为true就可能会带来安全上的一些问题.这也就为什么O7_DICTIONARY_ACCESSIBIL
- 比较全面的MySQL优化参考
dengkane
mysql
本文整理了一些MySQL的通用优化方法,做个简单的总结分享,旨在帮助那些没有专职MySQL DBA的企业做好基本的优化工作,至于具体的SQL优化,大部分通过加适当的索引即可达到效果,更复杂的就需要具体分析了,可以参考本站的一些优化案例或者联系我,下方有我的联系方式。这是上篇。
1、硬件层相关优化
1.1、CPU相关
在服务器的BIOS设置中,可
- C语言homework2,有一个逆序打印数字的小算法
dcj3sjt126com
c
#h1#
0、完成课堂例子
1、将一个四位数逆序打印
1234 ==> 4321
实现方法一:
# include <stdio.h>
int main(void)
{
int i = 1234;
int one = i%10;
int two = i / 10 % 10;
int three = i / 100 % 10;
- apacheBench对网站进行压力测试
dcj3sjt126com
apachebench
ab 的全称是 ApacheBench , 是 Apache 附带的一个小工具 , 专门用于 HTTP Server 的 benchmark testing , 可以同时模拟多个并发请求。前段时间看到公司的开发人员也在用它作一些测试,看起来也不错,很简单,也很容易使用,所以今天花一点时间看了一下。
通过下面的一个简单的例子和注释,相信大家可以更容易理解这个工具的使用。
- 2种办法让HashMap线程安全
flyfoxs
javajdkjni
多线程之--2种办法让HashMap线程安全
多线程之--synchronized 和reentrantlock的优缺点
多线程之--2种JAVA乐观锁的比较( NonfairSync VS. FairSync)
HashMap不是线程安全的,往往在写程序时需要通过一些方法来回避.其实JDK原生的提供了2种方法让HashMap支持线程安全.
- Spring Security(04)——认证简介
234390216
Spring Security认证过程
认证简介
目录
1.1 认证过程
1.2 Web应用的认证过程
1.2.1 ExceptionTranslationFilter
1.2.2 在request之间共享SecurityContext
1
- Java 位运算
Javahuhui
java位运算
// 左移( << ) 低位补0
// 0000 0000 0000 0000 0000 0000 0000 0110 然后左移2位后,低位补0:
// 0000 0000 0000 0000 0000 0000 0001 1000
System.out.println(6 << 2);// 运行结果是24
// 右移( >> ) 高位补"
- mysql免安装版配置
ldzyz007
mysql
1、my-small.ini是为了小型数据库而设计的。不应该把这个模型用于含有一些常用项目的数据库。
2、my-medium.ini是为中等规模的数据库而设计的。如果你正在企业中使用RHEL,可能会比这个操作系统的最小RAM需求(256MB)明显多得多的物理内存。由此可见,如果有那么多RAM内存可以使用,自然可以在同一台机器上运行其它服务。
3、my-large.ini是为专用于一个SQL数据
- MFC和ado数据库使用时遇到的问题
你不认识的休道人
sqlC++mfc
===================================================================
第一个
===================================================================
try{
CString sql;
sql.Format("select * from p
- 表单重复提交Double Submits
rensanning
double
可能发生的场景:
*多次点击提交按钮
*刷新页面
*点击浏览器回退按钮
*直接访问收藏夹中的地址
*重复发送HTTP请求(Ajax)
(1)点击按钮后disable该按钮一会儿,这样能避免急躁的用户频繁点击按钮。
这种方法确实有些粗暴,友好一点的可以把按钮的文字变一下做个提示,比如Bootstrap的做法:
http://getbootstrap.co
- Java String 十大常见问题
tomcat_oracle
java正则表达式
1.字符串比较,使用“==”还是equals()? "=="判断两个引用的是不是同一个内存地址(同一个物理对象)。 equals()判断两个字符串的值是否相等。 除非你想判断两个string引用是否同一个对象,否则应该总是使用equals()方法。 如果你了解字符串的驻留(String Interning)则会更好地理解这个问题。
- SpringMVC 登陆拦截器实现登陆控制
xp9802
springMVC
思路,先登陆后,将登陆信息存储在session中,然后通过拦截器,对系统中的页面和资源进行访问拦截,同时对于登陆本身相关的页面和资源不拦截。
实现方法:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23