- Spring框架整合Redis哨兵模式的实战教程
轩辕姐姐
本文还有配套的精品资源,点击获取简介:Spring框架作为Java企业级开发的重要组件,与Redis高性能键值数据库结合,特别是在其哨兵系统支持下,能实现Redis服务的高可用性。本文详细阐述了如何在Spring项目中整合Redis哨兵模式,包括依赖添加、配置哨兵系统、创建连接工厂、配置RedisTemplate以及异常处理等关键步骤。通过整合,可以确保应用数据存储和缓存的稳定性和连续性,适用于需
- Spring RedisTemplate中文乱码
NO爷
JavaSpringBootRedisJedis乱码
Redis客户端中文乱码网上非常常见的乱码,百度一搜大部分都是这种情况。如果不是此种情况请看下一节。redis-cliredis127.0.0.1:6379>set'name''中文'OKredis127.0.0.1:6379>get'name'"\xd6\xd0\xce\xc4"redis127.0.0.1:6379>客户端查看乱码,这个情况我们只要将修改客户端命令行就可以。redis-cli-
- [3-02-01].第14节:三方整合 - SpringData整合Redis集群
1.01^1000
阶段03:企业框架springboot
Redis大纲一、SpringBoot整合主从架构的Redis:1.1.问题说明:1.在Sentinel集群监管下的Redis哨兵架构中,其节点会因为自动故障转移而发生变化,Redis的客户端必须感知这种变化,及时更新连接信息2.SpringBoot中的RedisTemplate底层利用lettuce实现了节点的感知和自动切换,我们需要进行配置才可以实现这种动态上下线的情况。下面,我们通过一个测试
- Spring Boot——整合Redis
秋书一叶
SpringBootredisspringbootjava
SpringBoot整合Redis1.什么是Redis?2.Redis的特点3.什么是Springboot?4.SpringBoot整合Redis4.1下载和安装Redis-redis服务配置4.2Springboot导入依赖4.3配置Redis连接信息4.4创建Redis配置类4.5使用RedisTemplate或ReactiveRedisTemplate4.6通过注解整合5.示例5.1查询5.
- SprinBoot Redis工具类 + 序(反)列化 + jdk1.8 LocalDateTime Redis序列化
被惦记的猫
redisjava缓存
Redis工具类集成springboot依赖org.springframework.bootspring-boot-starter-data-redisimportorg.springframework.data.redis.core.RedisTemplate;importorg.springframework.stereotype.Component;importjavax.annotatio
- 基于API的Redis缓存实现
axinawang
springbootspringspringbootjava
1.使用RedisAPI进行业务数据缓存管理编写一个进行业务处理的类ApiCommentService,使用@Autowired注解注入RedisAPI中常用的RedisTemplate(类似于Java基础API中的JdbcTemplate);然后在数据查询、修改和删除三个方法中,根据业务需求分别进行数据缓存查询、缓存存储、缓存更新和缓存删除。同时,Comment数据对应缓存管理的key值都手动设
- Spring Boot 项目集成 Redis 问题:RedisTemplate 多余空格问题
我命由我12345
后端-问题清单springbootredis开发语言后端java-eejavaintellij-idea
//设置键值redisTemplate.opsForValue().set("name","张三");//设置带过期时间的键值redisTemplate.opsForValue().set("temp_key","临时值",60);//获取值Stringname=(String)redisTemplate.opsForValue().get("name");System.out.println(n
- 【Redis】Redis 的常见客户端汇总
敖云岚
Redisredisgithub数据库
目录一、命令行客户端二、图形界面的客户端三、Java客户端3.1SpringDataRedis3.2Jedis3.2.1连接池的配置3.3Lettuce3.3.1RedisTemplate工具类实现3.3.2自定义序列化器3.3.3StringRedisTemplate3.3.4集群配置3.3.4.1刷新节点集群拓扑动态感应四、RedisService的封装一、命令行客户端h:指定要连接的Redi
- 下面的java代码中 redisTemplate.opsForValue();和redisTemplate.boundValueOps(“key3“);测试String结构两种写法有什么区别呢?
gb4215287
springbootjavajava前端javascript
在SpringDataRedis中,`opsForValue()`和`boundValueOps("key")`都是用于操作Redis的String(或称为Value)数据结构。它们之间的区别与之前讨论的Hash操作类似,主要体现在使用方式和设计理念上。下面详细分析两者的区别:###核心区别概述|**特性**|`opsForValue()`|`boundValueOps("key")`||----
- SpringBoot结合Redis实现的分布式锁
u010303355
springbootredis分布式
一、使用RedisTemplate的简单实现1.在SpringBoot应用程序中添加Redis依赖项 org.springframework.boot spring-boot-starter-data-redis2.创建一个Redis分布式锁实现的类,示例代码:@SericepublicclassRedisLockSerice{ @Autowired privateRedisTemplatered
- redis实现分布式锁思路及redission分布式锁主流程分析
yfyh2021
redisjava开发语言
1.redis实现分布式锁思路首先,我们来看一段问题比较明显的代码。/***存在并发问题*@paramproductId*@return*/privateStringreduceStock1(StringproductId){Integerstock=Integer.parseInt(redisTemplate.opsForValue().get(productId));if(stock>0){i
- 在Java中操作Redis
不吃肘击
javaredisbootstrap
依赖引入我们在这里使用的是Spring框架中操作Redis的依赖包,他高度封装了操作Redis的API,使得我们的操作更加简便org.springframework.bootspring-boot-starter-data-redisRedisTemplate工具类我们在这里操作Redis的客户端是Another,我们要在java中对redis里面的数据进行操作,要借助于RedisTemplate
- Redis怎么避免热点数据问题
昔我往昔
Redisredisjunit数据库
使用RedisTemplate避免热点数据问题的解决方案、场景及示例:1.数据分片(Sharding)场景:高频读写的计数器(如文章阅读量统计)原理:将数据分散到多个子键,降低单个Key的压力。代码示例://写入分片数据publicvoidincrementShardedCounter(StringentityId,intshardCount,longdelta){StringbaseKey="c
- RedisTemplate的序列化配置方式详解
FAQEW
数据库相关序列化反序列化RedisRedisTemplate
在使用SpringDataRedis的RedisTemplate时,不同的序列化配置和操作方法会影响数据存储的格式和适用场景。以下是对不同配置和使用场景的详细说明:一、RedisTemplate的序列化配置方式及使用场景1.默认配置JDK序列化(JdkSerializationRedisSerializer)(不推荐)@BeanpublicRedisTemplateredisTemplate(Re
- Redis中的hash数据结构设置过期时间的坑!!!
小江爱学习~
redis哈希算法数据库
问题描述在使用RedisHash结构时,发现在异步操作完成后设置过期时间不生效,但在第一次写入后立即设置过期时间却可以正常工作。问题复现//情况一:不生效redisTemplate.opsForHash().put(uuid,"field1",value1);redisTemplate.opsForHash().put(uuid,"field2",value2);//...多次写入操作...red
- IDE中使用Spring Data Redis
烁岩
Redisidespringredis
步骤一:导入SpringDataRedis的maven坐标org.springframework.bootspring-boot-starter-data-redis步骤二:配置Redis数据源步骤三:编写配置类,创建RedisTemplate对象步骤四:通过RedisTemplate对象操作Redis
- Redis应用与Spring Boot集成实战(基于Redis Cluster)
樽酒ﻬق
java实战redisspringboot
目录Redis应用与SpringBoot集成实战(基于RedisCluster)Redis集群架构综合对比RedisCluster的应用场景SpringBoot集成RedisCluster实战1.添加依赖2.配置RedisCluster(YAML格式)3.使用RedisTemplate操作RedisCluster4.使用SpringCache简化缓存操作5.发布/订阅功能6.事务支持分布式锁应用分
- 苍穹外卖day03
描绘一抹色
苍穹外卖打卡redisjavaspringboot
店铺状态接口引入Redis,因为像存储店铺状态这种只有一个字段(没必要存储在数据库),且登录后台就要被访问的数据(加快查询速度,减少数据库压力)使用步骤:导入相关maven依赖、配置yml、连接工厂和Key序列化器(这里可以创建一个RedisTemplate做这些事并将其交给ioc容器管理,这样就不用每次用到RedisTemplate都去做一些重复的事情)依赖 org.springframew
- Spring Boot(二十二):RedisTemplate的List类型操作
图南随笔
springbootlistwindows
RedisTemplate和StringRedisTemplate的系列文章详见:SpringBoot(十七):集成和使用RedisSpringBoot(十八):RedisTemplate和StringRedisTemplateSpringBoot(十九):StringRedisTemplate的常用方法和注意事项SpringBoot(二十):RedisTemplate的序列化SpringBoot
- 从keys到SCAN:Redis批量删除的进化之路
凯哥Java
缓存Redis系列教程redis批量删除前缀匹配性能优化
标签:Redis、批量删除、前缀匹配、性能优化一、痛点分析:为什么需要批量删除指定前缀的键?在Redis使用过程中,我们经常会遇到这样的场景:需要对某一类数据进行清理,例如用户会话、缓存数据等,而这些数据通常以某种前缀命名(如user:session:*、cache:data:*)。如果直接通过redisTemplate.delete(key)删除单个键,需要手动指定所有键,效率极低且不可维护。如
- JdbcTemplate基本使用
呦呦鹿鸣Rzh
java开发语言
JdbcTemplate概述它是spring框架中提供的一个对象,是对原始繁琐的JdbcAPI对象的简单封装。spring框架为我们提供了很多的操作模板类。例如:操作关系型数据的JdbcTemplate和MbernateTemplate,操作nosql数据库的RedisTemplate,操作消息队列的JmsTemplate等等。JdbcTemplate开发步骤①导入spring-jdbc和spri
- redisTemplate.executePipelined命令
PureWT
Redisredisjava
redisTemplate.executePipelined是SpringDataRedis中的一个方法,它用于批量执行Redis命令,以提高性能。使用这个方法可以将多个Redis命令发送到服务器,而不需要等待每个命令的响应。以下是对这个方法的详细解释:1.方法概述方法签名publicListexecutePipelined(RedisCallbackaction);参数:RedisCallbac
- spring +kotlin 配置redis 和redis的常用方法
LCY133
spring后端springjava后端
在SpringBoot+Kotlin项目中,可以同时使用RedissonClient(提供分布式对象和高级功能)和RedisTemplate(SpringDataRedis的标准操作)。以下是完整配置和用法示例:1.添加依赖在build.gradle.kts中引入依赖:dependencies{//SpringDataRedisimplementation("org.springframework
- 在前后端分离项目中实现验证码功能
不高兴的富贵儿
javaspringboot前端
目录原理导入验证码依赖Redis工具类RedisUtils配置类CaptchaConfig验证码的文本生成器在SpringBoot里面配置RedisTemplate后端返回验证码接口登录验证(在登录方法之前执行)Login.vue原理通过工具类生成一条算术的验证规则,类似于这样的:1+1=2,其中1+1就是算术规则,2是算术结果。算术规则我们会通过图片流的形式返回给前端显示出来,让用户看到这个算术
- spring data redis使用pipline
南熏门前一只喵
redisspring-bootspringdataredisspring
使用stringRedisTemplate.executePipelined可以向redis批量提交一批命令,进行命令批处理。效率比遍历的方式执行单条语句要高。‘springdataredis使用pipline的两种方式。redisTemplate.executePipelined(newRedisCallback(){@OverridepublicLongdoInRedis(RedisConne
- 用Lua脚本实现Redis原子操作
Cloud_.
luaredis开发语言
1.环境准备依赖:在pom.xml中添加SpringDataRedis:org.springframework.bootspring-boot-starter-data-redis配置RedisTemplate:@ConfigurationpublicclassRedisConfig{@BeanpublicRedisTemplateredisTemplate(RedisConnectionFact
- springmvc集成多个redis实例
JAVA叶知秋
redisbootstrap数据库
1.配置bean2.redis实例使用@ComponentpublicclassRedisService{@Resource@Qualifier("redisTemplate1")publicRedisTemplateredisTemplate;/***缓存基本的对象,Integer、String、实体类等**@paramkey缓存的键值*@paramvalue缓存的值*/publicvoidse
- redis 用来实现排行榜的功能
追风林
redis数据库缓存
简单的用Redis的zset数据结构来实现。@Test@DisplayName("实现一个简单的排行榜")publicvoidzSetRankingTest(){ZSetOperationszSetOperations=redisTemplate.opsForZSet();//添加假数据到排行榜zSetOperations.add("ranking","张三",1500);zSetOperatio
- Spring Boot 整合 Redis 步骤详解
m0_74823094
面试学习路线阿里巴巴springbootredisbootstrap
文章目录1.引言2.添加依赖3.配置Redis连接信息4.创建Redis操作服务类5.使用RedisTemplate或ReactiveRedisTemplate6.测试Redis功能7.注意事项8.总结Redis是一个高性能的键值存储系统,常用于缓存、消息队列等多种场景。将Redis与SpringBoot结合使用可以极大提升应用的性能和响应速度。本文将详细介绍如何在SpringBoot应用中整合R
- Redis事务原理
超人在良家-阿启
redisredis数据库缓存
redis事务原理redis事务时基于SessionCallback实现的,因为要在一个连接里执行命令,那我们看看具体的实现,如下:redisTemplate.execute((RedisOperationsres)->{})对SessionCallback实现的是lambda表达式@ApiOperation(value="multi测试接口",notes="redis事务测试接口")@Reque
- mongodb3.03开启认证
21jhf
mongodb
下载了最新mongodb3.03版本,当使用--auth 参数命令行开启mongodb用户认证时遇到很多问题,现总结如下:
(百度上搜到的基本都是老版本的,看到db.addUser的就是,请忽略)
Windows下我做了一个bat文件,用来启动mongodb,命令行如下:
mongod --dbpath db\data --port 27017 --directoryperdb --logp
- 【Spark103】Task not serializable
bit1129
Serializable
Task not serializable是Spark开发过程最令人头疼的问题之一,这里记录下出现这个问题的两个实例,一个是自己遇到的,另一个是stackoverflow上看到。等有时间了再仔细探究出现Task not serialiazable的各种原因以及出现问题后如何快速定位问题的所在,至少目前阶段碰到此类问题,没有什么章法
1.
package spark.exampl
- 你所熟知的 LRU(最近最少使用)
dalan_123
java
关于LRU这个名词在很多地方或听说,或使用,接下来看下lru缓存回收的实现
1、大体的想法
a、查询出最近最晚使用的项
b、给最近的使用的项做标记
通过使用链表就可以完成这两个操作,关于最近最少使用的项只需要返回链表的尾部;标记最近使用的项,只需要将该项移除并放置到头部,那么难点就出现 你如何能够快速在链表定位对应的该项?
这时候多
- Javascript 跨域
周凡杨
JavaScriptjsonp跨域cross-domain
 
- linux下安装apache服务器
g21121
apache
安装apache
下载windows版本apache,下载地址:http://httpd.apache.org/download.cgi
1.windows下安装apache
Windows下安装apache比较简单,注意选择路径和端口即可,这里就不再赘述了。 2.linux下安装apache:
下载之后上传到linux的相关目录,这里指定为/home/apach
- FineReport的JS编辑框和URL地址栏语法简介
老A不折腾
finereportweb报表报表软件语法总结
JS编辑框:
1.FineReport的js。
作为一款BS产品,browser端的JavaScript是必不可少的。
FineReport中的js是已经调用了finereport.js的。
大家知道,预览报表时,报表servlet会将cpt模板转为html,在这个html的head头部中会引入FineReport的js,这个finereport.js中包含了许多内置的fun
- 根据STATUS信息对MySQL进行优化
墙头上一根草
status
mysql 查看当前正在执行的操作,即正在执行的sql语句的方法为:
show processlist 命令
mysql> show global status;可以列出MySQL服务器运行各种状态值,我个人较喜欢的用法是show status like '查询值%';一、慢查询mysql> show variab
- 我的spring学习笔记7-Spring的Bean配置文件给Bean定义别名
aijuans
Spring 3
本文介绍如何给Spring的Bean配置文件的Bean定义别名?
原始的
<bean id="business" class="onlyfun.caterpillar.device.Business">
<property name="writer">
<ref b
- 高性能mysql 之 性能剖析
annan211
性能mysqlmysql 性能剖析剖析
1 定义性能优化
mysql服务器性能,此处定义为 响应时间。
在解释性能优化之前,先来消除一个误解,很多人认为,性能优化就是降低cpu的利用率或者减少对资源的使用。
这是一个陷阱。
资源时用来消耗并用来工作的,所以有时候消耗更多的资源能够加快查询速度,保持cpu忙绿,这是必要的。很多时候发现
编译进了新版本的InnoDB之后,cpu利用率上升的很厉害,这并不
- 主外键和索引唯一性约束
百合不是茶
索引唯一性约束主外键约束联机删除
目标;第一步;创建两张表 用户表和文章表
第二步;发表文章
1,建表;
---用户表 BlogUsers
--userID唯一的
--userName
--pwd
--sex
create
- 线程的调度
bijian1013
java多线程thread线程的调度java多线程
1. Java提供一个线程调度程序来监控程序中启动后进入可运行状态的所有线程。线程调度程序按照线程的优先级决定应调度哪些线程来执行。
2. 多数线程的调度是抢占式的(即我想中断程序运行就中断,不需要和将被中断的程序协商)
a) 
- 查看日志常用命令
bijian1013
linux命令unix
一.日志查找方法,可以用通配符查某台主机上的所有服务器grep "关键字" /wls/applogs/custom-*/error.log
二.查看日志常用命令1.grep '关键字' error.log:在error.log中搜索'关键字'2.grep -C10 '关键字' error.log:显示关键字前后10行记录3.grep '关键字' error.l
- 【持久化框架MyBatis3一】MyBatis版HelloWorld
bit1129
helloworld
MyBatis这个系列的文章,主要参考《Java Persistence with MyBatis 3》。
样例数据
本文以MySQL数据库为例,建立一个STUDENTS表,插入两条数据,然后进行单表的增删改查
CREATE TABLE STUDENTS
(
stud_id int(11) NOT NULL AUTO_INCREMENT,
- 【Hadoop十五】Hadoop Counter
bit1129
hadoop
1. 只有Map任务的Map Reduce Job
File System Counters
FILE: Number of bytes read=3629530
FILE: Number of bytes written=98312
FILE: Number of read operations=0
FILE: Number of lar
- 解决Tomcat数据连接池无法释放
ronin47
tomcat 连接池 优化
近段时间,公司的检测中心报表系统(SMC)的开发人员时不时找到我,说用户老是出现无法登录的情况。前些日子因为手头上 有Jboss集群的测试工作,发现用户不能登录时,都是在Tomcat中将这个项目Reload一下就好了,不过只是治标而已,因为大概几个小时之后又会 再次出现无法登录的情况。
今天上午,开发人员小毛又找到我,要我协助将这个问题根治一下,拖太久用户难保不投诉。
简单分析了一
- java-75-二叉树两结点的最低共同父结点
bylijinnan
java
import java.util.LinkedList;
import java.util.List;
import ljn.help.*;
public class BTreeLowestParentOfTwoNodes {
public static void main(String[] args) {
/*
* node data is stored in
- 行业垂直搜索引擎网页抓取项目
carlwu
LuceneNutchHeritrixSolr
公司有一个搜索引擎项目,希望各路高人有空来帮忙指导,谢谢!
这是详细需求:
(1) 通过提供的网站地址(大概100-200个网站),网页抓取程序能不断抓取网页和其它类型的文件(如Excel、PDF、Word、ppt及zip类型),并且程序能够根据事先提供的规则,过滤掉不相干的下载内容。
(2) 程序能够搜索这些抓取的内容,并能对这些抓取文件按照油田名进行分类,然后放到服务器不同的目录中。
- [通讯与服务]在总带宽资源没有大幅增加之前,不适宜大幅度降低资费
comsci
资源
降低通讯服务资费,就意味着有更多的用户进入,就意味着通讯服务提供商要接待和服务更多的用户,在总体运维成本没有由于技术升级而大幅下降的情况下,这种降低资费的行为将导致每个用户的平均带宽不断下降,而享受到的服务质量也在下降,这对用户和服务商都是不利的。。。。。。。。
&nbs
- Java时区转换及时间格式
Cwind
java
本文介绍Java API 中 Date, Calendar, TimeZone和DateFormat的使用,以及不同时区时间相互转化的方法和原理。
问题描述:
向处于不同时区的服务器发请求时需要考虑时区转换的问题。譬如,服务器位于东八区(北京时间,GMT+8:00),而身处东四区的用户想要查询当天的销售记录。则需把东四区的“今天”这个时间范围转换为服务器所在时区的时间范围。
- readonly,只读,不可用
dashuaifu
jsjspdisablereadOnlyreadOnly
readOnly 和 readonly 不同,在做js开发时一定要注意函数大小写和jsp黄线的警告!!!我就经历过这么一件事:
使用readOnly在某些浏览器或同一浏览器不同版本有的可以实现“只读”功能,有的就不行,而且函数readOnly有黄线警告!!!就这样被折磨了不短时间!!!(期间使用过disable函数,但是发现disable函数之后后台接收不到前台的的数据!!!)
- LABjs、RequireJS、SeaJS 介绍
dcj3sjt126com
jsWeb
LABjs 的核心是 LAB(Loading and Blocking):Loading 指异步并行加载,Blocking 是指同步等待执行。LABjs 通过优雅的语法(script 和 wait)实现了这两大特性,核心价值是性能优化。LABjs 是一个文件加载器。RequireJS 和 SeaJS 则是模块加载器,倡导的是一种模块化开发理念,核心价值是让 JavaScript 的模块化开发变得更
- [应用结构]入口脚本
dcj3sjt126com
PHPyii2
入口脚本
入口脚本是应用启动流程中的第一环,一个应用(不管是网页应用还是控制台应用)只有一个入口脚本。终端用户的请求通过入口脚本实例化应用并将将请求转发到应用。
Web 应用的入口脚本必须放在终端用户能够访问的目录下,通常命名为 index.php,也可以使用 Web 服务器能定位到的其他名称。
控制台应用的入口脚本一般在应用根目录下命名为 yii(后缀为.php),该文
- haoop shell命令
eksliang
hadoophadoop shell
cat
chgrp
chmod
chown
copyFromLocal
copyToLocal
cp
du
dus
expunge
get
getmerge
ls
lsr
mkdir
movefromLocal
mv
put
rm
rmr
setrep
stat
tail
test
text
- MultiStateView不同的状态下显示不同的界面
gundumw100
android
只要将指定的view放在该控件里面,可以该view在不同的状态下显示不同的界面,这对ListView很有用,比如加载界面,空白界面,错误界面。而且这些见面由你指定布局,非常灵活。
PS:ListView虽然可以设置一个EmptyView,但使用起来不方便,不灵活,有点累赘。
<com.kennyc.view.MultiStateView xmlns:android=&qu
- jQuery实现页面内锚点平滑跳转
ini
JavaScripthtmljqueryhtml5css
平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且 url 链接最后会有“小尾巴”,就像#keleyi,今天我就介绍一款 jquery 做的滚动的特效,既可以设置滚动速度,又可以在 url 链接上没有“小尾巴”。
效果体验:http://keleyi.com/keleyi/phtml/jqtexiao/37.htmHTML文件代码:
&
- kafka offset迁移
kane_xie
kafka
在早前的kafka版本中(0.8.0),offset是被存储在zookeeper中的。
到当前版本(0.8.2)为止,kafka同时支持offset存储在zookeeper和offset manager(broker)中。
从官方的说明来看,未来offset的zookeeper存储将会被弃用。因此现有的基于kafka的项目如果今后计划保持更新的话,可以考虑在合适
- android > 搭建 cordova 环境
mft8899
android
1 , 安装 node.js
http://nodejs.org
node -v 查看版本
2, 安装 npm
可以先从 https://github.com/isaacs/npm/tags 下载 源码 解压到
- java封装的比较器,比较是否全相同,获取不同字段名字
qifeifei
非常实用的java比较器,贴上代码:
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.JsonConfig;
i
- 记录一些函数用法
.Aky.
位运算PHP数据库函数IP
高手们照旧忽略。
想弄个全天朝IP段数据库,找了个今天最新更新的国内所有运营商IP段,copy到文件,用文件函数,字符串函数把玩下。分割出startIp和endIp这样格式写入.txt文件,直接用phpmyadmin导入.csv文件的形式导入。(生命在于折腾,也许你们觉得我傻X,直接下载人家弄好的导入不就可以,做自己的菜鸟,让别人去说吧)
当然用到了ip2long()函数把字符串转为整型数
- sublime text 3 rust
wudixiaotie
Sublime Text
1.sublime text 3 => install package => Rust
2.cd ~/.config/sublime-text-3/Packages
3.mkdir rust
4.git clone https://github.com/sp0/rust-style
5.cd rust-style
6.cargo build --release
7.ctrl