根据错误日志,关键问题是Docker无法通过systemd的socket激活机制找到监听套接字。以下是针对性解决方案:1.修改Docker服务配置cat>/etc/systemd/system/docker.service/etc/docker/daemon.json<
Docker技术全景解析:从核心原理到实践应用
Liudef06小白
docker容器运维
Docker技术全景解析:从核心原理到实践应用引言:容器化革命的引擎2013年诞生的Docker并非容器技术的发明者,却成功地将Linux容器(LXC)这一底层技术转化为开发者友好的标准化工具。它通过镜像封装、环境一致性和资源隔离三大创新,解决了“在我机器上能跑,线上为什么不行”这一行业顽疾。Docker的核心突破在于创建了跨环境的应用交付标准——开发者构建的Docker镜像可在开发笔记本、测试服
java项目打包成 Docker 镜像几种方式
reiraoy
eureka云原生
1.准备工作安装Docker:确保本地或服务器上已安装Docker。创建SpringBoot项目:假设你已经有一个SpringBoot项目。2.使用docker-maven-plugin打包Docker镜像(1)在pom.xml中添加插件 com.spotify docker-maven-plugin 1.2.2 ${projec
容器革命:Docker 技术深度解析与未来趋势
小红花大酒店
Docker技术探秘docker容器运维
容器革命:Docker技术深度解析与未来趋势一、容器化技术的颠覆性价值在云计算与微服务架构蓬勃发展的今天,Docker作为容器化技术的代表,正深刻改变着软件交付的范式。传统虚拟机(VM)需要为每个应用实例配备完整的操作系统,导致资源浪费和启动延迟(分钟级)。而Docker通过操作系统级虚拟化,将应用及其依赖打包成轻量级容器,实现了秒级启动和MB级资源占用。这种技术突破使得开发团队能够以标准化方式构
一、Docker:一场颠覆应用部署与运维的容器革命
IvanCodes
Docker教程docker容器
作者:IvanCodes日期:2025年7月3日专栏:Docker教程在现代软件开发的世界里,Docker已经从一个新奇的工具演变成了一项基础性技术。它彻底改变了我们构建、打包、分发和运行应用程序的方式。无论你是开发者、运维工程师还是技术爱好者,理解Docker都是一项不可或缺的技能。本文将带你回顾Docker的发展历史,探索它能解决的实际问题,并清晰地解析其核心名词概念。一、Docker的“前世
Docker - Docker容器中安装Redis
那年夏天丶
LinuxDockerdocker容器运维
前言:前面我介绍了如何在centOS环境下安装mysql和docker,Docker-阿里云服务安装Docker-CSDN博客,Docker-Docker容器中安装Mysql-CSDN博客下面我在介绍一下如何安装redis。一丶.通过docker拉取需要安装的Redis版本通过docker拉取需要安装的redis版本如:dockerpullredis:7.0直接拉取最新版本:dockerpullr
Springboot项目快速部署(三):Idea插件docker工具,结合Docker-Compose集群部署
码专人L
Javaspringbootintellij-ideadocker
文章目录一、实现目的二、实现过程第一步第二步一、实现目的本文主要讲解如何通过docker-compose进行单服务器部署多服务场景的快速处理,按之前文章讲解的内容,我们如果需要部署多个服务的话,且需要运行多次docker插件,且每次运行时都需要调整不同的端口,避免端口冲突,如果一台服务器部署了45个服务的时候,那就会导致发版流程变的异常繁琐,这时候我们就可以通过docker-compose的sca
手动使用 Docker 启动 MinIO 分布式集群(推荐生产环境)
加油干sit!
微服务docker分布式容器
在生产环境中,MinIO集群通常部署在多个物理机或虚拟机上,每个节点运行一个MinIO容器,并通过Docker暴露API和Console端口。1.准备工作假设有4台服务器(也可以是同一台服务器的不同端口模拟,但不推荐生产使用):Server1:IP192.168.1.101Server2:IP192.168.1.102Server3:IP192.168.1.103Server4:IP192.168
【mongodb】mongodb数据备份与恢复
向往风的男子
运维日常DBAmongodb数据库
本站以分享各种运维经验和运维所需要的技能为主《python零基础入门》:python零基础入门学习《python运维脚本》:python运维脚本实践《shell》:shell学习《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战《k8》暂未更新《docker学习》暂未更新《ceph学习》ceph日常问题解决分享《日志收集》ELK+各种中间件《运维日常》运维日常《l
Docker 容器全生命周期操作指南
以下是Docker容器全生命周期操作指南,按步骤清晰划分,涵盖从镜像加载到容器销毁的完整流程:一、镜像加载与验证1.从.tar文件加载镜像sudodockerload-iubuntu18.04-boost1.88-cmake3.27-git_1.0.tar2.查看已加载的镜像sudodockerimages输出示例:REPOSITORYTAGIMAGEIDCREATEDSIZEubuntu18.0
Docker项目部署(黑马商城项目为例)
1.网络管理(容器互联)#创建自定义网络(项目隔离)dockernetworkcreatehmall-net//加入自定义网络的容器可以通过容器名互相访问#查看所有网络dockernetworkls#将现有容器加入网络(如MySQL)dockernetworkconnecthmall-netmysql--aliasdb2.MySQL容器部署(数据持久化)#启动MySQL容器dockerrun-d\
python# python:3.5 aarch64构建镜像
Ling丶落
centos
构建失败从ubuntu中尝试构建FROMpython:3.5-slimLABELMAINTAINER="
[email protected]"#installrelatedpackagesENVENVIRONMENTDOCKER_PRODWORKDIR/workCOPY./dataset.py/work/dataset.pyCOPY./model.py/work/model.pyCOPY./PyA
openai-agents记忆持久化(neo4j)
ZHOU_CAMP
oi_agentsagent中的记忆模块neo4jpython开发语言
目录环境安装模型配置Memory配置测试环境安装mem0ai[graph]安装uvpipinstall"mem0ai[graph]"docker启动neo4j数据库dockerrun\-p7474:7474-p7687:7687\-eNEO4J_AUTH=neo4j/password\neo4j:5模型配置fromdotenvimportload_dotenvimportosfromopenaii
在Linux环境下从0私有化部署Dify
在Linux环境下从0搭建Dify准备工作系统环境私有化部署下载Dify代码ZIP包启动Dify启动Docker容器访问Dify本地环境服务器环境准备工作因工作需要私有化部署公司内部的知识库,研究了一下准备采用Dify+RAG的方式实现,以下是具体步骤。系统环境服务器配置:官方建议2核4G以上;Liunx版本:RockyLinuxrelease9.4;Docker版本:28.1.1;Dify版本:
dockerfile详解
你是人间五月天
linux运维服务器
Dockerfile编写:每条保留字指令都必须为大写字母,且后面要跟随至少一个参数指令按照从上到下顺序执行#表示注释每条指令都会创建一个新的镜像层并对镜像进行提交Dockerfile保留字FROM基础镜像,当前新镜像是基于哪个镜像的,指定一个已经存在的镜像作为模板。Dockerfile第一条必须是FROM#FROM镜像名FROMhub.c.163.com/library/tomcatMAINTAI
go-micro教程 — 第一章 快速入门
go-micro教程—第一章快速入门1参考文档2所需依赖3安装micro3.1GoGet方式安装:3.2二进制版本3.3Docker镜像4运行micro服务4.1启动microserver服务4.2登录Micro4.3运行helloworld4.4查看运行结果4.4.1查看正在运行的服务的状态4.4.2查看服务的日志5调用服务5.1查看服务节点5.2使用API方式调用5.3客户端方式调用6创建服务
docker-compose 启动MongoDB后 导入json数据
观梦
docker-composemongodbpythondockershell
docker-compose启动MongoDB后导入json数据compose目录具体方法Dockerfilesetup.shdocker-compose.ymlcompose目录├──app│├──blueprints││├──common…│├──config.py│├──Dockerfile│├──main.py│├──requirements.txt│├──templates││├──…│
Docker 容器间通信:Link 与自定义网络
Docker容器间通信:Link与自定义网络关键词:Docker容器通信、容器网络模型、DockerLink、自定义网络、Bridge网络、Overlay网络、网络驱动摘要:本文深入解析Docker容器间通信的两种核心方式——传统Link机制与现代自定义网络方案。通过对比分析两者的技术原理、实现方式、适用场景及最佳实践,帮助读者理解Docker网络架构的演进逻辑。文章从容器网络基础概念出发,详细阐
备份远程主机上mysql,mongodb上数据,在docker容器中导入
酒千殇
数据备份dockermongodbmysql数据备份ubuntu
将远程机器中的mysql,mongodb数据备份到Ubuntu20.04中前提:一定要明确数据库的版本。已知:远程机器ip,mysql账号,密码。说明:以下命令均在Ubuntu20.04中执行查看远程mysql的版本:用mysqlworkbench连接上远程数据库。点击Query菜单,在空白框输入selectversion();在点击菜单栏中第二个闪电符号,执行这条命令。就可以在下面的输出中看到m
Tomcat镜像实战:掌握Dockerfile的编写以及发布项目
hunjinYang
Linuxtomcatdocker
1.为什么选择Docker部署Tomcat?在传统的JavaWeb项目部署中,我们通常需要手动安装JDK、配置Tomcat环境变量、手动部署WAR包,部署过程繁琐、不可重复、环境易出错。而Docker的出现彻底改变了这一局面。本博客将通过一个完整的Tomcat镜像构建与部署实例,带你逐步掌握以下技能:编写自己的Dockerfile构建定制化的Tomcat镜像(包含JDK与Tomcat)在容器中运行
Podman与Docker详细比较:从原理到使用
Podman与Docker详细比较:从原理到使用在容器化技术领域,Docker曾长期占据主导地位,但近年来Podman作为一款新兴的容器引擎逐渐受到关注。本文将从原理、使用等多个方面对Podman和Docker进行详细比较,帮助读者更好地了解两者的异同,以便在实际应用中做出合适的选择。一、原理比较1.容器引擎架构Docker采用客户端-服务器(C/S)架构,存在一个常驻后台的守护进程(docker
Docker 容器编排原理与使用详解
许先森森
技术杂文docker容器运维容器编排KubernetesDockerCompose
Docker容器编排原理与使用详解一、容器编排概述在容器技术领域,Docker容器以其轻量化、可移植性和快速部署的特性,极大地改变了应用程序的开发和部署方式。然而,当应用规模逐渐扩大,涉及多个容器的协同工作、资源管理、故障恢复等问题时,单纯使用Docker命令管理容器就显得力不从心。此时,容器编排技术应运而生。容器编排是指对多个容器进行自动化管理和协调的过程,它能够实现容器的部署、调度、伸缩、网络
Docker-compose容器编排
⼀、Docker-compose定义1.dockercompose是docker官⽅的开源项⽬,负责实现对docker容器集群的快速编排(容器,依赖,⽹络,挂载。。)2.compose是docker公司推出的⼀个⼯具软件,可以管理多个docker容器组成的应⽤3.需要定义⼀个YAML格式的配置⽂件docker-compose.yml,写好多个容器之间的调⽤关系4.使⽤compose的步骤、5.1.
docker拉取镜像报错:error pulling : download failed after attempts=6: dial tcp 69.162.134.178:443: i/o time
m0_47460678
dockerdocker容器运维
1.cd/etc找到resolv.conf命令:viresolv.conf添加内容:nameserver8.8.8.8nameserver8.8.4.4nameserver1.1.1.1保存并退出:wq2.cd/etc/docker找到daemon.json文件,没有则新建一个命令:vidaemon.json添加内容:{"dns":["8.8.8.8","8.8.4.4","1.1.1.1"],"
docker compose 安装 Neo4j
MonkeyKing.sun
dockerneo4j容器
使用DockerCompose安装Neo4j非常方便。以下是一个示例步骤,展示如何使用DockerCompose来安装并运行Neo4j。步骤1:安装Docker和DockerCompose确保你已经安装了Docker和DockerCompose。如果尚未安装,可以参考以下链接进行安装:Docker安装DockerCompose安装步骤2:创建DockerCompose文件在你的工作目录中创建一个d
第四十一篇-Docker安装Neo4j
木卫二号Coding
AI-LLM-实战dockerneo4j容器
创建目录mkdir/opt/neo4j-data创建dockerrun\-d--nameneo4j\-p7474:7474-p7687:7687\-v/opt/neo4j-data/data:/data\-v/opt/neo4j-data/logs:/logs\-v/opt/neo4j-data//conf:/var/lib/neo4j/conf\-v/opt/neo4j-data/plugins
在dify中通过http请求neo4j时为什么需要将localhost变为host.docker.internal
隆里卡那唔
AI问题解决httpneo4jdocker
在dify中通过http请求neo4j时为什么需要将http://localhost:7474/db/neo4j/tx/commit变为http://host.docker.internal:7474/db/neo4j/tx/commit在Dify中通过HTTP请求访问Neo4j时,将http://localhost:7474改为http://host.docker.internal:7474的原
Docker 安装 Neo4j 保姆级教程
Docker安装Neo4j保姆级教程本教程适用于零基础用户,详细讲解如何在Windows或Linux环境下通过Docker安装并配置Neo4j图数据库。Neo4j官方Docker文档1.环境准备已安装Docker(DockerDesktop官网)Linux和Windows均可2.创建挂载目录在宿主机上新建以下目录,用于数据持久化和配置挂载(以Linux为例,Windows可用资源管理器新建文件夹)
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