mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-25 23:11:02 +08:00
commit
31f11dc4e4
196
README.md
196
README.md
@ -49,93 +49,127 @@ LCTT的组成
|
|||||||
* 2014/10/08 提升bazz2为Core Translators成员。
|
* 2014/10/08 提升bazz2为Core Translators成员。
|
||||||
* 2014/11/04 提升zpl1025为Core Translators成员。
|
* 2014/11/04 提升zpl1025为Core Translators成员。
|
||||||
* 2014/12/25 提升runningwater为Core Translators成员。
|
* 2014/12/25 提升runningwater为Core Translators成员。
|
||||||
|
* 2015/04/19 发起 LFS-BOOK-7.7-systemd 项目。
|
||||||
|
* 2015/06/09 提升ictlyh和dongfengweixiao为Core Translators成员。
|
||||||
|
|
||||||
活跃成员
|
活跃成员
|
||||||
-------------------------------
|
-------------------------------
|
||||||
|
|
||||||
目前活跃成员有:
|
目前 TP 活跃成员有:
|
||||||
- CORE [wxy](https://github.com/wxy),
|
- CORE @wxy,
|
||||||
- CORE [carolinewuyan](https://github.com/carolinewuyan),
|
- CORE @carolinewuyan,
|
||||||
- CORE [DeadFire](https://github.com/DeadFire),
|
- CORE @DeadFire,
|
||||||
- CORE [geekpi](https://github.com/geekpi),
|
- CORE @geekpi,
|
||||||
- CORE [GOLinux](https://github.com/GOLinux),
|
- CORE @GOLinux,
|
||||||
- CORE [reinoir](https://github.com/reinoir),
|
- CORE @reinoir,
|
||||||
- CORE [bazz2](https://github.com/bazz2),
|
- CORE @bazz2,
|
||||||
- CORE [zpl1025](https://github.com/zpl1025),
|
- CORE @zpl1025,
|
||||||
- Senior [tinyeyeser](https://github.com/tinyeyeser),
|
- CORE @ictlyh,
|
||||||
- Senior [vito-L](https://github.com/vito-L),
|
- CORE @dongfengweixiao
|
||||||
- Senior [jasminepeng](https://github.com/jasminepeng),
|
- Senior @tinyeyeser,
|
||||||
- Senior [willqian](https://github.com/willqian),
|
- Senior @vito-L,
|
||||||
- Senior [vizv](https://github.com/vizv),
|
- Senior @jasminepeng,
|
||||||
- [runningwater](https://github.com/runningwater),
|
- Senior @willqian,
|
||||||
- [luoxcat](https://github.com/Luoxcat),
|
- Senior @vizv,
|
||||||
- [Vic020](https://github.com/Vic020),
|
- @ZTinoZ,
|
||||||
- [KayGuoWhu](https://github.com/KayGuoWhu),
|
- @Vic020,
|
||||||
- [alim0x](https://github.com/alim0x),
|
- @runningwater,
|
||||||
- [ZTinoZ](https://github.com/ZTinoZ),
|
- @KayGuoWhu,
|
||||||
- [2q1w2007](https://github.com/2q1w2007),
|
- @luoxcat,
|
||||||
- [flsf](https://github.com/flsf),
|
- @alim0x,
|
||||||
- [blueabysm](https://github.com/blueabysm),
|
- @2q1w2007,
|
||||||
- [barney-ro](https://github.com/barney-ro),
|
- @theo-l,
|
||||||
- [su-kaiyao](https://github.com/su-kaiyao),
|
- @FSSlc,
|
||||||
- [crowner](https://github.com/crowner),
|
- @su-kaiyao,
|
||||||
- [Linchenguang](https://github.com/Linchenguang),
|
- @blueabysm,
|
||||||
- [Linux-pdz](https://github.com/Linux-pdz),
|
- @flsf,
|
||||||
- [linuhap](https://github.com/linuhap),
|
- @martin2011qi,
|
||||||
- [yechunxiao19](https://github.com/yechunxiao19),
|
- @SPccman,
|
||||||
- [woodboow](https://github.com/woodboow),
|
- @wi-cuckoo,
|
||||||
- [SPccman](https://github.com/SPccman),
|
- @Linchenguang,
|
||||||
- [disylee](https://github.com/disylee),
|
- @linuhap,
|
||||||
- [cvsher](https://github.com/cvsher),
|
- @crowner,
|
||||||
- [ThomazL](https://github.com/ThomazL),
|
- @Linux-pdz,
|
||||||
- [Stevearzh](https://github.com/Stevearzh),
|
- @H-mudcup,
|
||||||
- [felixonmars](https://github.com/felixonmars),
|
- @yechunxiao19,
|
||||||
- [scusjs](https://github.com/scusjs),
|
- @woodboow,
|
||||||
- [johnhoow](https://github.com/johnhoow),
|
- @Stevearzh,
|
||||||
- [hyaocuk](https://github.com/hyaocuk),
|
- @disylee,
|
||||||
- [MikeCoder](https://github.com/MikeCoder),
|
- @cvsher,
|
||||||
- [theo-l](https://github.com/theo-l),
|
- @wwy-hust,
|
||||||
- [wangjiezhe](https://github.com/wangjiezhe),
|
- @johnhoow,
|
||||||
- [jiajia9linuxer](https://github.com/jiajia9linuxer),
|
- @felixonmars,
|
||||||
- [NearTan](https://github.com/NearTan),
|
- @TxmszLou,
|
||||||
- [l3b2w1](https://github.com/l3b2w1),
|
- @shipsw,
|
||||||
- [shipsw](https://github.com/shipsw),
|
- @scusjs,
|
||||||
- [boredivan](https://github.com/boredivan),
|
- @wangjiezhe,
|
||||||
- [Love-xuan](https://github.com/Love-xuan),
|
- @hyaocuk,
|
||||||
- [JonathanKang](https://github.com/JonathanKang),
|
- @MikeCoder,
|
||||||
- [luoyutiantang](https://github.com/luoyutiantang),
|
- @ZhouJ-sh,
|
||||||
- [owen-carter](https://github.com/owen-carter),
|
- @boredivan,
|
||||||
- [icybreaker](https://github.com/icybreaker),
|
- @goreliu,
|
||||||
- [tenght](https://github.com/tenght),
|
- @l3b2w1,
|
||||||
- [rogetfan](https://github.com/rogetfan),
|
- @JonathanKang,
|
||||||
- [liuaiping](https://github.com/liuaiping),
|
- @NearTan,
|
||||||
- [nd0104](https://github.com/nd0104),
|
- @jiajia9linuxer,
|
||||||
- [szrlee](https://github.com/szrlee),
|
- @Love-xuan,
|
||||||
- [lfzark](https://github.com/lfzark),
|
- @coloka,
|
||||||
- [ggaaooppeenngg](https://github.com/ggaaooppeenngg),
|
- @owen-carter,
|
||||||
- [CNprober](https://github.com/CNprober),
|
- @luoyutiantang,
|
||||||
- [coloka](https://github.com/coloka),
|
- @JeffDing,
|
||||||
- [213edu](https://github.com/213edu),
|
- @icybreaker,
|
||||||
- [guodongxiaren](https://github.com/guodongxiaren),
|
- @tenght,
|
||||||
- [Tanete](https://github.com/Tanete),
|
- @liuaiping,
|
||||||
- [zzlyzq](https://github.com/zzlyzq),
|
- @mtunique,
|
||||||
- [yujianxuechuan](https://github.com/yujianxuechuan),
|
- @rogetfan,
|
||||||
- [ailurus1991](https://github.com/ailurus1991),
|
- @nd0104,
|
||||||
- [FineFan](https://github.com/FineFan),
|
- @mr-ping,
|
||||||
- [shaohaolin](https://github.com/shaohaolin),
|
- @szrlee,
|
||||||
- [tomatoKiller](https://github.com/tomatoKiller),
|
- @lfzark,
|
||||||
- [CHINAANSHE](https://github.com/CHINAANSHE),
|
- @CNprober,
|
||||||
- [stduolc](https://github.com/stduolc),
|
- @DongShuaike,
|
||||||
- [Maclauring](https://github.com/Maclauring),
|
- @ggaaooppeenngg,
|
||||||
- [Hao-Ding](https://github.com/Hao-Ding),
|
- @haimingfg,
|
||||||
- [zsJacky](https://github.com/zsJacky),
|
- @213edu,
|
||||||
- [small-Wood](https://github.com/small-Wood),
|
- @Tanete,
|
||||||
- [cereuz](https://github.com/cereuz),
|
- @guodongxiaren,
|
||||||
- [lijhg](https://github.com/lijhg),
|
- @zzlyzq,
|
||||||
- [fbigun](https://github.com/fbigun),
|
- @FineFan,
|
||||||
|
- @yujianxuechuan,
|
||||||
|
- @Medusar,
|
||||||
|
- @shaohaolin,
|
||||||
|
- @ailurus1991,
|
||||||
|
- @liaoishere,
|
||||||
|
- @CHINAANSHE,
|
||||||
|
- @stduolc,
|
||||||
|
- @yupmoon,
|
||||||
|
- @tomatoKiller,
|
||||||
|
- @zhangboyue,
|
||||||
|
- @kingname,
|
||||||
|
- @KevinSJ,
|
||||||
|
- @zsJacky,
|
||||||
|
- @willqian,
|
||||||
|
- @Hao-Ding,
|
||||||
|
- @JygjHappy,
|
||||||
|
- @Maclauring,
|
||||||
|
- @small-Wood,
|
||||||
|
- @cereuz,
|
||||||
|
- @fbigun,
|
||||||
|
- @lijhg,
|
||||||
|
- @soooogreen,
|
||||||
|
|
||||||
|
|
||||||
(更新于2014/12/02,以Github contributors列表排名)
|
LFS 项目活跃成员有:
|
||||||
|
|
||||||
|
- @ictlyh
|
||||||
|
- @dongfengweixiao
|
||||||
|
- @wxy
|
||||||
|
- @H-mudcup
|
||||||
|
- @zpl1025
|
||||||
|
- @KevinSJ
|
||||||
|
- @Yuking-net
|
||||||
|
|
||||||
|
(更新于2015/06/09,以Github contributors列表排名)
|
||||||
|
|
||||||
谢谢大家的支持!
|
谢谢大家的支持!
|
||||||
|
|
||||||
|
146
published/20141211 Open source all over the world.md
Normal file
146
published/20141211 Open source all over the world.md
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
一个开源的世界
|
||||||
|
================================================================================
|
||||||
|
![](https://opensource.com/sites/default/files/styles/image-full-size/public/images/business/BUS_OpenSourceExperience_520x292_cm.png)
|
||||||
|
|
||||||
|
经过了一整天的Opensource.com[社区版主][1]年会,最后一项日程提了上来,内容只有“特邀嘉宾:待定”几个字。作为[Opensource.com][3]的项目负责人和社区管理员,[Jason Hibbets][2]起身解释道,“因为这个嘉宾有可能无法到场,因此我不想提前说是谁。在几个月前我问他何时有空过来,他给了我两个时间点,我选了其中一个。今天是这三周中Jim唯一能来的一天”。(译者注:Jim是指下文中提到的Jim Whitehurst,即红帽公司总裁兼首席执行官)
|
||||||
|
|
||||||
|
这句话在版主们(Moderators)中引起一阵轰动,他们从世界各地赶来参加此次的[拥抱开源大会(All Things Open Conference)][4]。版主们纷纷往前挪动椅子,仔细聆听。
|
||||||
|
|
||||||
|
“他会首先作半个小时的演讲,然后会回答几个提问。”,Jason说道。
|
||||||
|
|
||||||
|
会场的门开着,似乎一直在等着这位大人物的出现。这时,会场前唯一一个空位上来了一位高个子。
|
||||||
|
|
||||||
|
“大家好!”,这个家伙开口了。他没穿正装,只是衬衫和休闲裤。
|
||||||
|
|
||||||
|
这时会场中第二高个子的人,红帽全球意识部门(Global Awareness)的高级主管[Jeff Mackanic][5],告诉他大部分社区版主今天都在场,然后让每个人开始作简单的自我介绍。
|
||||||
|
|
||||||
|
“我叫[Jen Wike Huger][6],负责Opensource.com的内容管理,很高兴见到大家。”
|
||||||
|
|
||||||
|
“我叫[Nicole][7]。是[ByWater Solutions][8]的副总裁,我们在做免费的开源库。我到各地旅行并教会人们如何使用软件。”
|
||||||
|
|
||||||
|
“我叫[Robin][9],从2013年开始参与版主项目。我在OSDC做了一些事情,工作是在[City of the Hague][10]维护[网站][11]。”
|
||||||
|
|
||||||
|
“我叫[Marcus Hanwell][12],来自英格兰,在[Kitware][13]工作。同时,我是FOSS science software的技术总监,和国家实验室在[Titan][14] Z和[Gpu programming][15]方面合作。我主要使用[Gentoo][16]和[KDE][17]。最后,我很激动能参与到FOSS和开源科学。”
|
||||||
|
|
||||||
|
“我叫[Phil Shapiro][18],是华盛顿的一个小图书馆的28个Linux工作站的管理员。我视各位为我的同事。非常高兴能一起交流分享,贡献力量。我主要关注FOSS和自豪感的关系,以及FOSS如何提升自豪感。”
|
||||||
|
|
||||||
|
“我叫[Joshua Holm][19]。我大多数时间都在关注系统更新,以及帮助人们在网上找工作。”
|
||||||
|
|
||||||
|
“我叫[Mel Chernoff][20],在红帽工作,和[Jason Hibbets][22]和[Mark Bohannon][23]一起主要关注[政府][21]渠道方面。”
|
||||||
|
|
||||||
|
“我叫[Scott Nesbitt][24],写过很多东西,使用FOSS很久了。我是个普通人,不是系统管理员,也不是程序员,只希望能更加高效工作。我帮助人们在商业和生活中使用FOSS。”
|
||||||
|
|
||||||
|
“我叫[Luis Ibanez][25],刚加入[Google][26]。我对DIY和FOSS感兴趣。”
|
||||||
|
|
||||||
|
“我叫[Remy DeCausemaker][27],在[RIT MAGIC Center][28]的黑客学院(Resident Hackademic),也是[交互式游戏和媒体系][29]的一个兼职教授。现在为Opensource.com写作将近四年。”
|
||||||
|
|
||||||
|
“你在[新FOSS Minor][30]教书?!”,Jim说道,“很酷!”
|
||||||
|
|
||||||
|
“我叫[Jason Baker][31]。我是红帽的一个云专家,主要做[OpenStack][32]方面的工作。”
|
||||||
|
|
||||||
|
“我叫[Mark Bohannan][33],是红帽全球开放协议的一员,在华盛顿外工作。和Mel一样,我花了相当多时间写作,也从法律和政府部门中找合作者。我做了一个很好的小册子来讨论正在发生在政府中的积极变化。”
|
||||||
|
|
||||||
|
“我叫[Jason Hibbets][34],我组织了这次讨论。”
|
||||||
|
|
||||||
|
会场中一片笑声。
|
||||||
|
|
||||||
|
“我也组织了这个讨论,可以这么说,”这个棕红色头发笑容灿烂的家伙说道。笑声持续一会逐渐平息。
|
||||||
|
|
||||||
|
我当时在他左边,时不时从记录的间隙中抬头看一眼,我注意到淡淡微笑背后的那个令人瞩目的人,是自2008年1月起开始领导红帽公司的CEO [Jim Whitehurst][35]。
|
||||||
|
|
||||||
|
“我有世界上最好的工作,”稍稍向后靠、叉腿抱头,Whitehurst开始了演讲。“我开始领导红帽,在世界各地旅行到处看看情况。在这里的七年中,FOSS和广泛的开源创新所发生的最美好的事情是开源已经脱离了条条框框。我现在认为,信息技术正处在FOSS之前所在的位置。我们可以预见FOSS从一个替代品走向创新驱动力。我们的用户也看到了这一点。他们用FOSS并不是因为它便宜,而是因为它能带来可控和创新的解决方案。这也是个全球现象。比如,我刚才还在印度,然后发现那里的用户拥抱开源的两个理由:一个是创新,另一个是那里的市场有些特殊,需要完全的可控。”
|
||||||
|
|
||||||
|
“[孟买证券交易所][36]想得到源代码并加以控制,五年前这种事情在证券交易领域就没有听说过。那时FOSS正在重复发明轮子。今天看来,实际上大数据的每件事情都出现在FOSS领域。几乎所有的新框架,语言和方法论,包括移动通讯(尽管不包括设备),都首先发生在开源世界。”
|
||||||
|
|
||||||
|
“这是因为用户数量已经达到了相当的规模。这不只是红帽遇到的情况,[Google][37],[Amazon][38],[Facebook][39]等也出现这样的情况。他们想解决自己的问题,用开源的方式。忘掉许可协议吧,开源绝不仅如此。我们建立了一个交通工具,一套规则,例如[Hadoop][40],[Cassandra][41]和其他工具。事实上,开源驱动创新。例如,Hadoop是在厂商们意识到规模带来的问题时的一个解决方案。他们实际上有足够的资金和资源来解决自己的问题。开源是许多领域的默认技术方案。这在一个更加注重内容的世界中更是如此,例如[3D打印][42]和其他使用信息内容的实体产品。”
|
||||||
|
|
||||||
|
“源代码的开源确实很酷,但开源不应当仅限于此。在各行各业不同领域开源仍有可以用武之地。我们要问下自己:‘开源能够为教育,政府,法律带来什么?其它的呢?其它的领域如何能学习我们?’”
|
||||||
|
|
||||||
|
“还有内容的问题。内容在现在是免费的,当然我们可以投资更多的免费内容,不过我们也需要商业模式围绕的内容。这是我们更应该关注的。如果你相信开放的创新更好,那么我们需要更多的商业模式。”
|
||||||
|
|
||||||
|
“教育让我担心,其相比与‘社区’它更关注‘内容’。例如,无论我走到哪里,大学的校长们都会说,‘等等,难道教育将会免费?!’对于下游来说FOSS免费很棒,但别忘了上游很强大。免费课程很棒,但我们同样需要社区来不断迭代和完善。这是很多人都在做的事情,Opensource.com是一个提供交流的社区。问题不是‘我们如何控制内容’,也不是‘如何建立和分发内容’,而是要确保它处在不断的完善当中,而且能给其他领域提供有价值的参考。”
|
||||||
|
|
||||||
|
“改变世界的潜力是无穷无尽的,我们已经取得了很棒的进步。”六年前我们痴迷于制定宣言,我们说‘我们是领导者’。我们用错词了,因为那潜在意味着控制。积极的参与者们同样也不能很好理解……[Máirín Duffy][43]提出了[催化剂][44]这个词。然后我们组成了红帽,不断地促进行动,指引方向。”
|
||||||
|
|
||||||
|
“Opensource.com也是其他领域的催化剂,而这正是它的本义所在,我希望你们也这样认为。当时的内容质量和现在比起来都令人难以置信。你可以看到每季度它都在进步。谢谢你们付出的时间!谢谢成为了催化剂!这是一个让世界变得更好的机会。我想听听你们的看法。”
|
||||||
|
|
||||||
|
我瞥了一下桌子,发现几个人眼中带泪。
|
||||||
|
|
||||||
|
然后Whitehurst又回顾了大会的开放教育议题。“极端一点看,如果你有一门[Ulysses][45]的公开课。在这里你能和一群人一起合作体验课堂。这样就和代码块一样的:大家一起努力,代码随着时间不断改进。”
|
||||||
|
|
||||||
|
在这一点上,我有发言权。当谈论其FOSS和学术团体之间的差异,像“基础”和“可能不调和”这些词语都跳了出来。
|
||||||
|
|
||||||
|
**Remy**: “倒退带来死亡。如果你在论文或者发布的代码中犯了一个错误,有可能带来十分严重的后果。学校一直都是避免失败寻求正确答案的地方。复制意味着抄袭。轮子在一遍遍地教条地被发明。FOSS让你能快速失败,但在学术界,你只能带来无效的结果。”
|
||||||
|
|
||||||
|
**Nicole**: “学术界有太多自我的家伙,你们需要一个发布经理。”
|
||||||
|
|
||||||
|
**Marcus**: “为了合作,你必须展示自己不懂的地方,这些发生在幕后。奖励模型是所有你信任的东西,我们需要改变它。尽可能多地发表,我们最后会发布,但希望能尽早地释放努力。”
|
||||||
|
|
||||||
|
**Luis**: “团队和分享应该优先考虑,红帽可以多向它们强调这一点。”
|
||||||
|
|
||||||
|
**Jim**: “还有公司在其中扮演积极角色了吗?”
|
||||||
|
|
||||||
|
[Phil Shapiro][46]: “我对FOSS的临界点感兴趣。Fed没有改用[LibreOffice][47]把我逼疯了。我们没有在软件上花税款,也不应当在字处理软件或者微软的Office上浪费税钱。”
|
||||||
|
|
||||||
|
**Jim**: “我们经常提倡这一点。我们能做更多吗?这是个问题。首先,我们在我们的产品涉足的地方取得了进步。我们在政府中有坚实的专营权。我们比私有公司平均花费更多。银行和电信业都和政府挨着。我们在欧洲做的更好,我认为在那工作有更低的税。下一代计算就像‘终结者’,我们到处取得了进步,但仍然需要忧患意识。”
|
||||||
|
|
||||||
|
突然,门开了。Jim转身向门口站着的执行助理点头。他要去参加下一场会了。他并拢双腿,站着向前微倾。然后,他再次向每个人的工作和奉献表示感谢,微笑着出了门……留给我们更多的激励。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: https://opensource.com/business/14/12/jim-whitehurst-inspiration-open-source
|
||||||
|
|
||||||
|
作者:[Remy][a]
|
||||||
|
译者:[fyh](https://github.com/fyh)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:https://opensource.com/users/remyd
|
||||||
|
[1]:http://opensource.com/community-moderator-program
|
||||||
|
[2]:https://twitter.com/jhibbets
|
||||||
|
[3]:http://opensource.com/
|
||||||
|
[4]:http://allthingsopen.org/
|
||||||
|
[5]:http://opensource.com/users/mackanic
|
||||||
|
[6]:https://twitter.com/JenWike
|
||||||
|
[7]:http://opensource.com/users/nengard
|
||||||
|
[8]:http://bywatersolutions.com/
|
||||||
|
[9]:http://opensource.com/life/13/7/community-spotlight-robin-muilwijk
|
||||||
|
[10]:https://en.wikipedia.org/wiki/The_Hague
|
||||||
|
[11]:http://www.denhaag.nl/en.htm
|
||||||
|
[12]:https://twitter.com/mhanwell
|
||||||
|
[13]:http://www.kitware.com/
|
||||||
|
[14]:http://www.nvidia.com/gtx-700-graphics-cards/gtx-titan-z/
|
||||||
|
[15]:https://en.wikipedia.org/wiki/General-purpose_computing_on_graphics_processing_units
|
||||||
|
[16]:https://www.gentoo.org/
|
||||||
|
[17]:http://kde.org/
|
||||||
|
[18]:https://twitter.com/philshapiro
|
||||||
|
[19]:http://opensource.com/community/13/9/contributor-spotlight-joshua-holm
|
||||||
|
[20]:http://opensource.com/users/melanie
|
||||||
|
[21]:http://opensource.com/government
|
||||||
|
[22]:https://twitter.com/jhibbets
|
||||||
|
[23]:https://twitter.com/markbotech
|
||||||
|
[24]:http://scottnesbitt.me/
|
||||||
|
[25]:http://opensource.com/users/luis-ibanez
|
||||||
|
[26]:http://google.com/
|
||||||
|
[27]:http://twitter.com/remy_d
|
||||||
|
[28]:http://foss.rit.edu/
|
||||||
|
[29]:http://igm.rit.edu/
|
||||||
|
[30]:http://www.rit.edu/news/story.php?id=50590
|
||||||
|
[31]:https://twitter.com/jehb
|
||||||
|
[32]:http://openstack.org/
|
||||||
|
[33]:https://twitter.com/markbotech
|
||||||
|
[34]:https://twitter.com/jhibbets
|
||||||
|
[35]:http://www.redhat.com/en/about/company/management/james-whitehurst
|
||||||
|
[36]:http://www.bseindia.com/
|
||||||
|
[37]:http://google.com/
|
||||||
|
[38]:https://mail.corp.redhat.com/service/home/%7E/Amazon
|
||||||
|
[39]:https://mail.corp.redhat.com/service/home/%7E/Facebook
|
||||||
|
[40]:https://hadoop.apache.org/
|
||||||
|
[41]:https://cassandra.apache.org/
|
||||||
|
[42]:https://en.wikipedia.org/wiki/3D_printing
|
||||||
|
[43]:https://twitter.com/mairin
|
||||||
|
[44]:http://jobs.redhat.com/life-at-red-hat/our-culture/
|
||||||
|
[45]:http://www.gutenberg.org/ebooks/4300
|
||||||
|
[46]:https://twitter.com/philshapiro
|
||||||
|
[47]:http://libreoffice.org/
|
@ -0,0 +1,86 @@
|
|||||||
|
7 个驱动开源发展的社区
|
||||||
|
================================================================================
|
||||||
|
不久前,开源模式还被成熟的工业级厂商以怀疑的态度认作是叛逆小孩的玩物。如今,开源的促进会和基金会在一长列的供应商提供者的支持下正蓬勃发展,而他们将开源模式视作创新的关键。
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/0_opensource-title-100539095-orig.jpg)
|
||||||
|
|
||||||
|
### 技术的开放发展驱动着创新 ###
|
||||||
|
|
||||||
|
在过去的 20 几年间,技术的开源推进已被视作驱动创新的关键因素。即使那些以前将开源视作威胁的公司也开始接受这个观点 — 例如微软,如今它在一系列的开源的促进会中表现活跃。到目前为止,大多数的开源推进都集中在软件方面,但甚至这个也正在改变,因为社区已经开始向开源硬件倡议方面聚拢。这里介绍 7 个成功地在硬件和软件方面同时促进和发展开源技术的组织。
|
||||||
|
|
||||||
|
### OpenPOWER 基金会 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/1_openpower-100539100-orig.jpg)
|
||||||
|
|
||||||
|
[OpenPOWER 基金会][2] 由 IBM, Google, Mellanox, Tyan 和 NVIDIA 于 2013 年共同创建,在与开源软件发展相同的精神下,旨在驱动开放协作硬件的发展,在过去的 20 几年间,开源软件发展已经找到了肥沃的土壤。
|
||||||
|
|
||||||
|
IBM 通过开放其基于 Power 架构的硬件和软件技术,向使用 Power IP 的独立硬件产品提供许可证等方式为基金会的建立播下种子。如今超过 70 个成员共同协作来为基于 Linux 的数据中心提供自定义的开放服务器,组件和硬件。
|
||||||
|
|
||||||
|
去年四月,在比最新基于 x86 系统快 50 倍的数据分析能力的新的 POWER8 处理器的服务器的基础上, OpenPOWER 推出了一个技术路线图。七月, IBM 和 Google 发布了一个固件堆栈。去年十月见证了 NVIDIA GPU 带来加速 POWER8 系统的能力和来自 Tyan 的第一个 OpenPOWER 参考服务器。
|
||||||
|
|
||||||
|
### Linux 基金会 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/2_the-linux-foundation-100539101-orig.jpg)
|
||||||
|
|
||||||
|
于 2000 年建立的 [Linux 基金会][2] 如今成为掌控着历史上最大的开源协同开发成果,它有着超过 180 个合作成员和许多独立成员及学生成员。它赞助 Linux 核心开发者的工作并促进、保护和推进 Linux 操作系统,并协调软件的协作开发。
|
||||||
|
|
||||||
|
它最为成功的协作项目包括 Code Aurora Forum (一个拥有为移动无线产业服务的企业财团),MeeGo (一个为移动设备和 IVI [注:指的是车载消息娱乐设备,为 In-Vehicle Infotainment 的简称] 构建一个基于 Linux 内核的操作系统的项目) 和 Open Virtualization Alliance (开放虚拟化联盟,它促进自由和开源软件虚拟化解决方案的采用)。
|
||||||
|
|
||||||
|
### 开放虚拟化联盟 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/3_open-virtualization-alliance-100539102-orig.jpg)
|
||||||
|
|
||||||
|
[开放虚拟化联盟(OVA)][3] 的存在目的为:通过提供使用案例和对具有互操作性的通用接口和 API 的发展提供支持,来促进自由、开源软件的虚拟化解决方案,例如 KVM 的采用。KVM 将 Linux 内核转变为一个虚拟机管理程序。
|
||||||
|
|
||||||
|
如今, KVM 已成为和 OpenStack 共同使用的最为常见的虚拟机管理程序。
|
||||||
|
|
||||||
|
### OpenStack 基金会 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/4_the-openstack-foundation-100539096-orig.jpg)
|
||||||
|
|
||||||
|
原本作为一个 IaaS(基础设施即服务) 产品由 NASA 和 Rackspace 于 2010 年启动,[OpenStack 基金会][4] 已成为最大的开源项目聚居地之一。它拥有超过 200 家公司成员,其中包括 AT&T, AMD, Avaya, Canonical, Cisco, Dell 和 HP。
|
||||||
|
|
||||||
|
大约以 6 个月为一个发行周期,基金会的 OpenStack 项目开发用于通过一个基于 Web 的仪表盘,命令行工具或一个 RESTful 风格的 API 来控制或调配流经一个数据中心的处理存储池和网络资源。至今为止,基金会支持的协同开发已经孕育出了一系列 OpenStack 组件,其中包括 OpenStack Compute(一个云计算网络控制器,它是一个 IaaS 系统的主要部分),OpenStack Networking(一个用以管理网络和 IP 地址的系统) 和 OpenStack Object Storage(一个可扩展的冗余存储系统)。
|
||||||
|
|
||||||
|
### OpenDaylight ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/5_opendaylight-100539097-orig.jpg)
|
||||||
|
|
||||||
|
作为来自 Linux 基金会的另一个协作项目, [OpenDaylight][5] 是一个由诸如 Dell, HP, Oracle 和 Avaya 等行业厂商于 2013 年 4 月建立的联合倡议。它的任务是建立一个由社区主导、开源、有工业支持的针对软件定义网络( SDN: Software-Defined Networking)的包含代码和蓝图的框架。其思路是提供一个可直接部署的全功能 SDN 平台,而不需要其他组件,供应商可提供附件组件和增强组件。
|
||||||
|
|
||||||
|
### Apache 软件基金会 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/6_apache-software-foundation-100539098-orig.jpg)
|
||||||
|
|
||||||
|
[Apache 软件基金会 (ASF)][7] 是将近 150 个顶级项目的聚居地,这些项目涵盖从开源的企业级自动化软件到与 Apache Hadoop 相关的分布式计算的整个生态系统。这些项目分发企业级、可免费获取的软件产品,而 Apache 协议则是为了让无论是商业用户还是个人用户更方便地部署 Apache 的产品。
|
||||||
|
|
||||||
|
ASF 是 1999 年成立的一个会员制,非盈利公司,以精英为其核心 — 要成为它的成员,你必须首先在基金会的一个或多个协作项目中做出积极贡献。
|
||||||
|
|
||||||
|
### 开放计算项目 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/7_open-compute-project-100539099-orig.jpg)
|
||||||
|
|
||||||
|
作为 Facebook 重新设计其 Oregon 数据中心的副产物, [开放计算项目][7] 旨在发展针对数据中心的开源硬件解决方案。 OCP 是一个由廉价无浪费的服务器、针对 Open Rack(为数据中心设计的机架标准,来让机架集成到数据中心的基础设施中) 的模块化 I/O 存储和一个相对 "绿色" 的数据中心设计方案等构成。
|
||||||
|
|
||||||
|
OCP 董事会成员包括来自 Facebook,Intel,Goldman Sachs,Rackspace 和 Microsoft 的代表。
|
||||||
|
|
||||||
|
OCP 最近宣布了有两种可选的许可证: 一个类似 Apache 2.0 的允许衍生工作的许可证,和一个更规范的鼓励将更改回馈到原有软件的许可证。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.networkworld.com/article/2866074/opensource-subnet/7-communities-driving-open-source-development.html
|
||||||
|
|
||||||
|
作者:[Thor Olavsrud][a]
|
||||||
|
译者:[FSSlc](https://github.com/FSSlc)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.networkworld.com/author/Thor-Olavsrud/
|
||||||
|
[1]:http://openpowerfoundation.org/
|
||||||
|
[2]:http://www.linuxfoundation.org/
|
||||||
|
[3]:https://openvirtualizationalliance.org/
|
||||||
|
[4]:http://www.openstack.org/foundation/
|
||||||
|
[5]:http://www.opendaylight.org/
|
||||||
|
[6]:http://www.apache.org/
|
||||||
|
[7]:http://www.opencompute.org/
|
@ -0,0 +1,268 @@
|
|||||||
|
如何在 Ubuntu 中管理和使用 逻辑卷管理 LVM
|
||||||
|
================================================================================
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/652x202xbanner-1.png.pagespeed.ic.VGSxDeVS9P.png)
|
||||||
|
|
||||||
|
在我们之前的文章中,我们介绍了[什么是 LVM 以及能用 LVM 做什么][1],今天我们会给你介绍一些 LVM 的主要管理工具,使得你在设置和扩展安装时更游刃有余。
|
||||||
|
|
||||||
|
正如之前所述,LVM 是介于你的操作系统和物理硬盘驱动器之间的抽象层。这意味着你的物理硬盘驱动器和分区不再依赖于他们所在的硬盘驱动和分区。而是你的操作系统所见的硬盘驱动和分区可以是由任意数目的独立硬盘汇集而成的或是一个软件磁盘阵列。
|
||||||
|
|
||||||
|
要管理 LVM,这里有很多可用的 GUI 工具,但要真正理解 LVM 配置发生的事情,最好要知道一些命令行工具。这当你在一个服务器或不提供 GUI 工具的发行版上管理 LVM 时尤为有用。
|
||||||
|
|
||||||
|
LVM 的大部分命令和彼此都非常相似。每个可用的命令都由以下其中之一开头:
|
||||||
|
|
||||||
|
- Physical Volume (物理卷) = pv
|
||||||
|
- Volume Group (卷组)= vg
|
||||||
|
- Logical Volume (逻辑卷)= lv
|
||||||
|
|
||||||
|
物理卷命令用于在卷组中添加或删除硬盘驱动。卷组命令用于为你的逻辑卷操作更改显示的物理分区抽象集。逻辑卷命令会以分区形式显示卷组,使得你的操作系统能使用指定的空间。
|
||||||
|
|
||||||
|
### 可下载的 LVM 备忘单 ###
|
||||||
|
|
||||||
|
为了帮助你理解每个前缀可用的命令,我们制作了一个备忘单。我们会在该文章中介绍一些命令,但仍有很多你可用但没有介绍到的命令。
|
||||||
|
|
||||||
|
该列表中的所有命令都要以 root 身份运行,因为你更改的是会影响整个机器系统级设置。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/01/lvm-cheatsheet.png)
|
||||||
|
|
||||||
|
### 如何查看当前 LVM 信息 ###
|
||||||
|
|
||||||
|
你首先需要做的事情是检查你的 LVM 设置。s 和 display 命令可以和物理卷(pv)、卷组(vg)以及逻辑卷(lv)一起使用,是一个找出当前设置的好起点。
|
||||||
|
|
||||||
|
display 命令会格式化输出信息,因此比 s 命令更易于理解。对每个命令你会看到名称和 pv/vg 的路径,它还会给出空闲和已使用空间的信息。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/01/539x225xpvdisplay.png.pagespeed.ic.u2XV5LBTYa.png)
|
||||||
|
|
||||||
|
最重要的信息是 PV 名称和 VG 名称。用这两部分信息我们可以继续进行 LVM 设置。
|
||||||
|
|
||||||
|
### 创建一个逻辑卷 ###
|
||||||
|
|
||||||
|
逻辑卷是你的操作系统在 LVM 中使用的分区。创建一个逻辑卷,首先需要拥有一个物理卷和卷组。下面是创建一个新的逻辑卷所需要的全部命令。
|
||||||
|
|
||||||
|
#### 创建物理卷 ####
|
||||||
|
|
||||||
|
我们会从一个全新的没有任何分区和信息的硬盘开始。首先找出你将要使用的磁盘。(/dev/sda, sdb, 等)
|
||||||
|
|
||||||
|
> 注意:记住所有的命令都要以 root 身份运行或者在命令前面添加 'sudo' 。
|
||||||
|
|
||||||
|
fdisk -l
|
||||||
|
|
||||||
|
如果之前你的硬盘从未格式化或分区过,在 fdisk 的输出中你很可能看到类似下面的信息。这完全正常,因为我们会在下面的步骤中创建需要的分区。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/fdisk.png.pagespeed.ce.AmAEsxm-7Q.png)
|
||||||
|
|
||||||
|
我们的新磁盘位置是 /dev/sdb,让我们用 fdisk 命令在磁盘上创建一个新的分区。
|
||||||
|
|
||||||
|
这里有大量能创建新分区的 GUI 工具,包括 [Gparted][2],但由于我们已经打开了终端,我们将使用 fdisk 命令创建需要的分区。
|
||||||
|
|
||||||
|
在终端中输入以下命令:
|
||||||
|
|
||||||
|
fdisk /dev/sdb
|
||||||
|
|
||||||
|
这会使你进入到一个特殊的 fdisk 提示符中。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/627x145xfdisk00.png.pagespeed.ic.I7S8bjoXQG.png)
|
||||||
|
|
||||||
|
以指定的顺序输入命令创建一个使用新硬盘 100% 空间的主分区并为 LVM 做好了准备。如果你需要更改分区的大小或想要多个分区,我建议使用 GParted 或自己了解一下关于 fdisk 命令的使用。
|
||||||
|
|
||||||
|
**警告:下面的步骤会格式化你的硬盘驱动。确保在进行下面步骤之前你的硬盘驱动中没有任何有用的信息。**
|
||||||
|
|
||||||
|
- n = 创建新分区
|
||||||
|
- p = 创建主分区
|
||||||
|
- 1 = 成为磁盘上的首个分区
|
||||||
|
|
||||||
|
输入 enter 键两次以接受默认的第一个和最后一个柱面。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/562x216xfdisk01.png.pagespeed.ic.DsSZ38kWcA.png)
|
||||||
|
|
||||||
|
用下面的命令准备 LVM 所使用的分区。
|
||||||
|
|
||||||
|
- t = 更改分区类型
|
||||||
|
- 8e = 更改为 LVM 分区类型
|
||||||
|
|
||||||
|
核实并将信息写入硬盘。
|
||||||
|
|
||||||
|
- p = 查看分区设置使得在写入更改到磁盘之前可以回看
|
||||||
|
- w = 写入更改到磁盘
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/560x339xfdisk03.png.pagespeed.ic.FC8foICZsb.png)
|
||||||
|
|
||||||
|
运行这些命令之后,会退出 fdisk 提示符并返回到终端的 bash 提示符中。
|
||||||
|
|
||||||
|
输入 pvcreate /dev/sdb1 在刚创建的分区上新建一个 LVM 物理卷。
|
||||||
|
|
||||||
|
你也许会问为什么我们不用一个文件系统格式化分区,不用担心,该步骤在后面。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/pvcreate.png.pagespeed.ce.W7VAr-ig3t.png)
|
||||||
|
|
||||||
|
#### 创建卷组 ####
|
||||||
|
|
||||||
|
现在我们有了一个指定的分区和创建好的物理卷,我们需要创建一个卷组。很幸运这只需要一个命令。
|
||||||
|
|
||||||
|
vgcreate vgpool /dev/sdb1
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/vgcreate.png.pagespeed.ce.fVLzSmPZou.png)
|
||||||
|
|
||||||
|
vgpool 是新创建的卷组的名称。你可以使用任何你喜欢的名称,但建议标签以 vg 开头,以便后面你使用它时能意识到这是一个卷组。
|
||||||
|
|
||||||
|
#### 创建逻辑卷 ####
|
||||||
|
|
||||||
|
创建 LVM 将使用的逻辑卷:
|
||||||
|
|
||||||
|
lvcreate -L 3G -n lvstuff vgpool
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/lvcreate.png.pagespeed.ce.vupLB-LJEW.png)
|
||||||
|
|
||||||
|
-L 命令指定逻辑卷的大小,在该情况中是 3 GB,-n 命令指定卷的名称。 指定 vgpool 以便 lvcreate 命令知道从什么卷获取空间。
|
||||||
|
|
||||||
|
#### 格式化并挂载逻辑卷 ####
|
||||||
|
|
||||||
|
最后一步是用一个文件系统格式化新的逻辑卷。如果你需要选择一个 Linux 文件系统的帮助,请阅读 [如果根据需要选取最合适的文件系统][3]。
|
||||||
|
|
||||||
|
mkfs -t ext3 /dev/vgpool/lvstuff
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/571x424xmkfs.png.pagespeed.ic.ERMan1Mz0P.png)
|
||||||
|
|
||||||
|
创建挂载点并将卷挂载到你可以使用的地方。
|
||||||
|
|
||||||
|
mkdir /mnt/stuff
|
||||||
|
mount -t ext3 /dev/vgpool/lvstuff /mnt/stuff
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/510x69xmount.png.pagespeed.ic.k0i1tvqgcV.png)
|
||||||
|
|
||||||
|
#### 重新设置逻辑卷大小 ####
|
||||||
|
|
||||||
|
逻辑卷的一个好处是你能使你的存储物理地变大或变小,而不需要移动所有东西到一个更大的硬盘。另外,你可以添加新的硬盘并同时扩展你的卷组。或者如果你有一个不使用的硬盘,你可以从卷组中移除它使得逻辑卷变小。
|
||||||
|
|
||||||
|
这里有三个用于使物理卷、卷组和逻辑卷变大或变小的基础工具。
|
||||||
|
|
||||||
|
注意:这些命令中的每个都要以 pv、vg 或 lv 开头,取决于你的工作对象。
|
||||||
|
|
||||||
|
- resize – 能压缩或扩展物理卷和逻辑卷,但卷组不能
|
||||||
|
- extend – 能使卷组和逻辑卷变大但不能变小
|
||||||
|
- reduce – 能使卷组和逻辑卷变小但不能变大
|
||||||
|
|
||||||
|
让我们来看一个如何向刚创建的逻辑卷 "lvstuff" 添加新硬盘驱动的例子。
|
||||||
|
|
||||||
|
#### 安装并格式化新硬盘驱动 ####
|
||||||
|
|
||||||
|
按照上面创建新分区并更改分区类型为 LVM(8e) 的步骤安装一个新硬盘驱动。然后用 pvcreate 命令创建一个 LVM 能识别的物理卷。
|
||||||
|
|
||||||
|
#### 添加新硬盘到卷组 ####
|
||||||
|
|
||||||
|
要添加新的硬盘到一个卷组,你只需要知道你的新分区,在我们的例子中是 /dev/sdc1,以及想要添加到的卷组的名称。
|
||||||
|
|
||||||
|
这会添加新物理卷到已存在的卷组中。
|
||||||
|
|
||||||
|
vgextend vgpool /dev/sdc1
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/vgextend.png.pagespeed.ce.atRPT1yg5f.png)
|
||||||
|
|
||||||
|
#### 扩展逻辑卷 ####
|
||||||
|
|
||||||
|
调整逻辑卷的大小,我们需要指出的是通过大小而不是设备来扩展。在我们的例子中,我们会添加一个 8GB 的硬盘驱动到我们的 3GB vgpool。我们可以用 lvextend 或 lvresize 命令使该空间可用。
|
||||||
|
|
||||||
|
lvextend -L8G /dev/vgpool/lvstuff
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/lvextend1.png.pagespeed.ce.6scXbQVUTT.png)
|
||||||
|
|
||||||
|
当这个命令工作的时候你会发现它实际上重新设置逻辑卷大小为 8GB 而不是我们期望的将 8GB 添加到已存在的卷上。要添加剩余的可用 3GB 你需要用下面的命令。
|
||||||
|
|
||||||
|
lvextend -L+3G /dev/vgpool/lvstuff
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/430x85xlvextend2.png.pagespeed.ic.7aBiTBrW03.png)
|
||||||
|
|
||||||
|
现在我们的逻辑卷已经是 11GB 大小了。
|
||||||
|
|
||||||
|
#### 扩展文件系统 ####
|
||||||
|
|
||||||
|
逻辑卷是 11GB 大小但是上面的文件系统仍然只有 3GB。要使文件系统使用整个的 11GB 可用空间你需要用 resize2fs 命令。你只需要指定 resize2fs 到 11GB 逻辑卷它就会帮你完成其余的工作。
|
||||||
|
|
||||||
|
resize2fs /dev/vgpool/lvstuff
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/650x150xresize2fs.png.pagespeed.ic.Mx74EdMuk_.png)
|
||||||
|
|
||||||
|
**注意:如果你使用除 ext3/4 之外的文件系统,请查看调整你的文件系统大小的工具。**
|
||||||
|
|
||||||
|
#### 压缩逻辑卷 ####
|
||||||
|
|
||||||
|
如果你想从卷组中移除一个硬盘驱动你可以按照上面的步骤反向操作,并用 lvreduce 或 vgreduce 命令代替。
|
||||||
|
|
||||||
|
1. 调整文件系统大小 (调整之前确保已经移动文件到硬盘驱动安全的地方)
|
||||||
|
1. 减小逻辑卷 (除了 + 可以扩展大小,你也可以用 - 压缩大小)
|
||||||
|
1. 用 vgreduce 从卷组中移除硬盘
|
||||||
|
|
||||||
|
#### 备份逻辑卷 ####
|
||||||
|
|
||||||
|
快照是一些新的高级文件系统提供的功能,但是 ext3/4 文件系统并没有快照的功能。LVM 快照最棒的是你的文件系统永不掉线,你可以拥有你想要的任何大小而不需要额外的硬盘空间。
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/652x202xbanner-2.png.pagespeed.ic.VtOUuqYX1W.png)
|
||||||
|
|
||||||
|
LVM 获取快照的时候,会有一张和逻辑卷完全相同的“照片”,该“照片”可以用于在不同的硬盘上进行备份。生成一个备份的时候,任何需要添加到逻辑卷的新信息会如往常一样写入磁盘,但会跟踪更改使得原始快照永远不会损毁。
|
||||||
|
|
||||||
|
要创建一个快照,我们需要创建拥有足够空闲空间的逻辑卷,用于保存我们备份的时候会写入该逻辑卷的任何新信息。如果驱动并不是经常写入,你可以使用很小的一个存储空间。备份完成的时候我们只需要移除临时逻辑卷,原始逻辑卷会和往常一样。
|
||||||
|
|
||||||
|
#### 创建新快照 ####
|
||||||
|
|
||||||
|
创建 lvstuff 的快照,用带 -s 标记的 lvcreate 命令。
|
||||||
|
|
||||||
|
lvcreate -L512M -s -n lvstuffbackup /dev/vgpool/lvstuff
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/597x68xlvcreate-snapshot.png.pagespeed.ic.Rw2ivtcpPg.png)
|
||||||
|
|
||||||
|
这里我们创建了一个只有 512MB 的逻辑卷,因为该硬盘实际上并不会使用。512MB 的空间会保存备份时产生的任何新数据。
|
||||||
|
|
||||||
|
#### 挂载新快照 ####
|
||||||
|
|
||||||
|
和之前一样,我们需要创建一个挂载点并挂载新快照,然后才能从中复制文件。
|
||||||
|
|
||||||
|
mkdir /mnt/lvstuffbackup
|
||||||
|
mount /dev/vgpool/lvstuffbackup /mnt/lvstuffbackup
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/565x68xmount-snapshot.png.pagespeed.ic.pVMkhK1o4x.png)
|
||||||
|
|
||||||
|
#### 复制快照和删除逻辑卷 ####
|
||||||
|
|
||||||
|
你剩下需要做的是从 /mnt/lvstuffbackup/ 中复制所有文件到一个外部的硬盘或者打包所有文件到一个文件。
|
||||||
|
|
||||||
|
**注意:tar -c 会创建一个归档文件,-f 要指出归档文件的名称和路径。要获取 tar 命令的帮助信息,可以在终端中输入 man tar。**
|
||||||
|
|
||||||
|
tar -cf /home/rothgar/Backup/lvstuff-ss /mnt/lvstuffbackup/
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/627x67xsnapshot-backup.png.pagespeed.ic.tw-2AK_lfZ.png)
|
||||||
|
|
||||||
|
记住备份时候写到 lvstuff 的所有文件都会在我们之前创建的临时逻辑卷中被跟踪。确保备份的时候你有足够的空闲空间。
|
||||||
|
|
||||||
|
备份完成后,卸载卷并移除临时快照。
|
||||||
|
|
||||||
|
umount /mnt/lvstuffbackup
|
||||||
|
lvremove /dev/vgpool/lvstuffbackup/
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/630x102xlvremove.png.pagespeed.ic.yBWk47X6lF.png)
|
||||||
|
|
||||||
|
#### 删除逻辑卷 ####
|
||||||
|
|
||||||
|
要删除一个逻辑卷,你首先需要确保卷已经卸载,然后你可以用 lvremove 命令删除它。逻辑卷删除后你可以移除卷组,卷组删除后你可以删除物理卷。
|
||||||
|
|
||||||
|
这是所有移除我们创建的卷和组的命令。
|
||||||
|
|
||||||
|
umount /mnt/lvstuff
|
||||||
|
lvremove /dev/vgpool/lvstuff
|
||||||
|
vgremove vgpool
|
||||||
|
pvremove /dev/sdb1 /dev/sdc1
|
||||||
|
|
||||||
|
![](http://cdn5.howtogeek.com/wp-content/uploads/2011/02/580x185xdelete-lvm.png.pagespeed.ic.3zJTo0Zu9k.png)
|
||||||
|
|
||||||
|
这些已经囊括了关于 LVM 你需要了解的大部分知识。如果你有任何关于这些讨论的经验,请在下面的评论框中和大家分享。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.howtogeek.com/howto/40702/how-to-manage-and-use-lvm-logical-volume-management-in-ubuntu/
|
||||||
|
|
||||||
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[1]:https://linux.cn/article-5953-1.html
|
||||||
|
[2]:http://www.howtogeek.com/howto/17001/how-to-format-a-usb-drive-in-ubuntu-using-gparted/
|
||||||
|
[3]:http://www.howtogeek.com/howto/33552/htg-explains-which-linux-file-system-should-you-choose/
|
320
published/201505/20140804 Group Test--Linux Text Editors.md
Normal file
320
published/201505/20140804 Group Test--Linux Text Editors.md
Normal file
@ -0,0 +1,320 @@
|
|||||||
|
五款 Linux 文本编辑器测评
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
> Mayank Sharma 测试了5款不仅仅是能处理文字的超强文本编辑器。
|
||||||
|
|
||||||
|
如果你使用Linux已经有很长一段时间,你知道,不管是编辑一款app的配置文件,还是修改shell脚本,或者编写/查看代码,类似LibreOffice的工具并不适合。尽管字面上看起来都是一样,但是你并不需要一个文字处理器来完成这些任务;你需要的是一个文本编辑器。
|
||||||
|
|
||||||
|
在这个测评中,我们将着眼于5款更能胜任繁重文本工作的轻量级的文本编辑器。他们支持语法高亮,像拼写检查一样轻松处理代码缩进。你可以像你复制/粘贴文本那样容易地使用它们记录宏以及管理代码片段。
|
||||||
|
|
||||||
|
得益于它们的插件,使得它们足以抗衡其它的以文本为中心的应用程序,一些简单的文本编辑器甚至超出了它们的设计目标。它们能胜任一个源代码编辑器的任务,甚至就是一个集成开发环境。
|
||||||
|
|
||||||
|
Emacs和Vim是两款最流行和强大的纯文本编辑器。但是,由于一些原因,我们在这个测评中并没有包括它们。首先,如果你使用它们中的任何一个,那么恭喜你:你不需要更换了。其次,它们都有陡峭的学习曲线,尤其是那些熟悉了桌面环境的用户:他们很更愿意投入其他有图形界面的文本编辑器。
|
||||||
|
|
||||||
|
### 目录: ###
|
||||||
|
|
||||||
|
#### Gedit ####
|
||||||
|
|
||||||
|
- URL:http://projects.gnome.org/gedit/
|
||||||
|
- 版本: 3.10
|
||||||
|
- 许可证: GPL
|
||||||
|
- Gnome的默认文本编辑器准备好挑战了吗?
|
||||||
|
|
||||||
|
#### Kate ####
|
||||||
|
|
||||||
|
- URL: www.kate-editor.org
|
||||||
|
- 版本: 3.11
|
||||||
|
- 许可证: LGPL/GPL
|
||||||
|
- Kate会挑战命运吗?
|
||||||
|
|
||||||
|
#### Sublime Text ####
|
||||||
|
|
||||||
|
- URL: www.sublimetext.com
|
||||||
|
- 版本: 2.0.2
|
||||||
|
- 许可证: Proprietary
|
||||||
|
- 在自由的土地上的带有黄金般的心脏的专利软件。
|
||||||
|
|
||||||
|
#### UltraEdit ####
|
||||||
|
|
||||||
|
- URL: www.ultraedit.com
|
||||||
|
- 版本: 4.1.0.4
|
||||||
|
- 许可证: Proprietary
|
||||||
|
- 足够证明它的价值了吗?
|
||||||
|
|
||||||
|
#### jEdit ####
|
||||||
|
|
||||||
|
- URL: www.jedit.org
|
||||||
|
- 版本: 5.1.0
|
||||||
|
- 许可证: GPL
|
||||||
|
- 基于Java的编辑器是否会毁掉其他编辑器的世界?
|
||||||
|
|
||||||
|
|
||||||
|
### 关键标准 ###
|
||||||
|
|
||||||
|
除了Gedit和jEdit以外的所有工具,都是通过其推荐的安装方法安装在Fedora和Ubuntu上。前者已经兼容默认的Gnome桌面,后者仍然固执地反对安装在Fedora上。由于这些是相对简单的应用程序,他们没有复杂的依赖,唯一例外的是jEdit,它要求要有Oracle Java。
|
||||||
|
|
||||||
|
得益于Gnome和KDE持续的努力,所有编辑器无论在哪个桌面上的外观看起来很好,功能也很正常。这不仅是作为评价的标准,也意味着你不再受制于你的桌面环境兼容的工具。
|
||||||
|
|
||||||
|
除了它们独特的功能,我们也对所有候选者测试了常规的文本编辑功能。然而,它们并没有被设计为模仿现代字处理器的所有功能,我们也不以此评判。
|
||||||
|
|
||||||
|
|
||||||
|
### 编程语言支持 ###
|
||||||
|
|
||||||
|
UltraEdit 能进行语法高亮、代码折叠以及拥有项目管理的能力。也有一个罗列源文件中所有函数的功能列表,但并不适用于我们测试的任何代码文件。UltraEdit也支持HTML5,有一个能添加常用HTML标记的HTML工具栏。
|
||||||
|
|
||||||
|
即使Gnome的默认文本编辑器Gedit,也有几个面向编码的功能特性,例如括号匹配、自动缩进以及为包括C, C++, Java, HTML, XML, Python, Perl, 以及许多其它编程语言进行语法高亮。
|
||||||
|
|
||||||
|
如果你需要更多的编程辅助功能,看一下Sublime和Kate。
|
||||||
|
|
||||||
|
Sublime支持多种编程语言并且能为(那些流行的)C#, D, Dylan, Erlang, Groovy, Haskell, Lisp, Lua, MATLAB, OCaml, R, 甚至 SQL 进行语法高亮。如果这还不够,你可以下载插件以支持更多的语言。另外,它的语法高亮功能提供了多个可定制选项。这个应用程序也会进行括号匹配,确保代码段都正确,Sublime的自动补全功能也支持用户创建的变量。就像Komodo IDE,Sublime也可以显示一个全部源代码的滚动预览图,这对于长代码文件导航和在文件中的不同部分跳转很方便。Sublime最好的功能之一就是能在编辑器内部运行特定语言,例如C++, Python, Ruby等的代码,当然假设在你的电脑上安装有编译器以及其它系统工具。省时间而且不用再开终端.
|
||||||
|
|
||||||
|
你也可以用插件在Kate中开启构建系统功能。另外,你可以为GDB调试器添加一个简单的前端。Kate能和Git,Subversion以及Mercurial版本控制系统一起工作,也提供了一些项目管理的功能。除了能为超过180种语言进行语法高亮,它支持所有的这些辅助功能,例如括号匹配,自动补全和自动缩进。它也支持代码折叠,甚至在一个程序中折叠函数。
|
||||||
|
|
||||||
|
唯一的遗憾的是jEdit,它声称自己是一个程序员的文本编辑器,但它缺少其他的基本功能,例如代码折叠,它甚至不能提示或者补全函数.
|
||||||
|
|
||||||
|
**评分:**
|
||||||
|
|
||||||
|
- Gedit:3/5
|
||||||
|
- Kate:5/5
|
||||||
|
- Sublime:5/5
|
||||||
|
- UltraEdit:3/5
|
||||||
|
- jEdit:1/5
|
||||||
|
|
||||||
|
|
||||||
|
### 键盘控制 ###
|
||||||
|
|
||||||
|
高级文本编辑器的用户希望能完全通过键盘控制和操作,一些应用程序甚至支持用户自定义快捷方式的键盘绑定。
|
||||||
|
|
||||||
|
你可以轻松的使用Gedit的扩展键盘快捷键。可以在编辑文件时通过工具的快捷键调用工具,例如对一个文档进行拼写检查。你可以看到应用程序内部的一系列默认快捷键,但并没有图形化的方式去自定义它们。相似的,在Sublime中自定义键盘绑定,你需要修改它的XML的键盘映射文件。Sublime由于缺少定义键盘快捷键的图形化界面而饱受批评,但长期使用的用户支持当前的基于文件的机制:这给了他们更多的控制能力。
|
||||||
|
|
||||||
|
UltraEdit为它"一切都可自定义"的座右铭感到自豪,这也包括键盘快捷键。你可以自定义菜单导航的热键,以及定义你自己的访问大量功能的组合键映射。
|
||||||
|
|
||||||
|
除了完全可自定义的键盘快捷键以外,jEdit也有为Emacs预定义的键映射。Kate在这方面尤其令人映像深刻。它有简单可访问的自定义键绑定窗口。你可以更改默认的键,或者定义替代的键。另外,Kate也有一个能使用户使用Vi键操作Kate的Vi模式。
|
||||||
|
|
||||||
|
**评分:**
|
||||||
|
|
||||||
|
- Gedit:2/5
|
||||||
|
- Kate:5/5
|
||||||
|
- Sublime:3/5
|
||||||
|
- UltraEdit:4/5
|
||||||
|
- jEdit:5/5
|
||||||
|
|
||||||
|
### 片段和宏 ###
|
||||||
|
|
||||||
|
宏通过自动化重复的步骤帮助你降低花费在编辑和组织数据上的时间,而代码片段通过创建可重用的源代码块为程序员扩展类似的功能。这两者都能节省你的时间。
|
||||||
|
|
||||||
|
标准的Gedit安装没有这两种功能中的任何一种,但是你可以通过独立的插件启用这些功能。片段插件随Gedit一起发布,但在Gedit内启用宏插件,则需要你手动下载和安装(被称为gedit-macropy,托管在GitHub上)。
|
||||||
|
|
||||||
|
Kate也同样通过插件的形式启用片段功能。一旦加入,插件也增加了PHP,Bash和Java的片段库。你可以在侧边栏中显示片段列表以便于访问。可以通过右击片段或者快捷键组合方式编辑它的内容。然而,令人惊讶的是,它不支持宏-尽管用户从2002年就不断要求!
|
||||||
|
|
||||||
|
jEdit也有一个启用片段的插件。它还可以从用户行为中记录宏或者你也可以用BeanShell 脚本语言(BeanShell支持像Perl和JavaScript那样将脚本对象封装为简单的方法)中写宏。jEdit也有一个可以从jEdit的网站中下载多种宏的插件。
|
||||||
|
|
||||||
|
Sublime有创建片段和宏的内建功能,也有为大多数编程语言经常使用的函数多种片段。
|
||||||
|
|
||||||
|
在UltraEdit中片段被称为智能模板,就像Sublime中一样,你可以根据正在编辑的源代码文件类型插入片段。要完成宏记录功能,UltraEdit还有集成了一个基于JavaScript的脚本语言引擎来完成自动任务。你也可以从该编辑器的网站中下载用户提交的宏和脚本。
|
||||||
|
|
||||||
|
**评分:**
|
||||||
|
|
||||||
|
- Gedit:3/5
|
||||||
|
- Kate:1/5
|
||||||
|
- Sublime:5/5
|
||||||
|
- UltraEdit:5/5
|
||||||
|
- jEdit:5/5
|
||||||
|
|
||||||
|
|
||||||
|
### 易用性 ###
|
||||||
|
|
||||||
|
不像那些简陋的文本编辑器,这些文本编辑器在这方面可以适应从文档写作者到程序员的各种用户的需要。与精简应用程序相反,他们的开发者在寻找添加更多功能的途径。
|
||||||
|
|
||||||
|
尽管第一眼看上去这次测评中的大部分应用有一个很相似的布局,经过仔细的检查,你会发现一些可用性的差异。我们通过用户界面的合理使用来介绍它们的功能和特性,而不是铺天盖地地告诉读者。
|
||||||
|
|
||||||
|
#### Gedit: 4/5 ####
|
||||||
|
|
||||||
|
Gedit的外观很普通,它有一个带有很少的菜单和按钮的简单界面。这是一把双刃剑,因为有些用户可能不会发现它真正的潜能。
|
||||||
|
|
||||||
|
Gedit可以在选项卡中打开多个文件,这些选项卡可以重排和在多个 Gedit窗口之间移动。用户可以选择通过插件来启用侧边栏来浏览文件或者在底部面板显示工具输出内容。这个应用程序会检测到被其它应用程序更改的文件并可以重新加载该文件。
|
||||||
|
|
||||||
|
为了适配Gnome,在应用程序的最新版本中做了大量的 UI 修改。然而修改还还不稳定,尽管包括了所有的功能,但是菜单交互的一些插件还需要升级。
|
||||||
|
|
||||||
|
![在展示一个有功能的应用程序和将它们所有的东西曝光给用户之间有一个很好的平衡。Geddit隐藏了它的大部分功能。](http://www.linuxvoice.com/wp-content/uploads/2014/07/gedit-web.png)
|
||||||
|
|
||||||
|
*在功能与界面之间取得了良好的平衡,Gedit将其大部分功能隐藏在背后。*
|
||||||
|
|
||||||
|
#### Kate: 5/5 ####
|
||||||
|
|
||||||
|
尽管用户界面的主要部分和Gedit相似,Kate可以在两边显示选项卡并且它的菜单更加丰富。该应用程序平易近人,吸引用户来挖掘它的其它功能。
|
||||||
|
|
||||||
|
Kate可以在KDE的KIO支持的所有协议上透明地打开和保存文件,包括通过HTTP, FTP, SSH, SMB 和 WebDAV。你可以用这个应用同时处理多个文件。但不同于大部分应用程序传统的水平选项卡选择栏,Kate在屏幕的两个方向都有选项卡。左侧的侧边栏显示打开的文件列表。需要同时查看一个文件不同部分的程序员也会感激它可以水平或者竖直分隔界面的能力。
|
||||||
|
|
||||||
|
![Kate能搭建为功能丰富的集成开发环境](http://www.linuxvoice.com/wp-content/uploads/2014/08/kate-web.png)
|
||||||
|
|
||||||
|
*Kate能搭建为功能丰富的集成开发环境。*
|
||||||
|
|
||||||
|
#### Sublime: 5/5 ####
|
||||||
|
|
||||||
|
Sublime支持你在不同方式同时查看多达四个文件。当你在集中精力编程时,它也有一个只显示文件和菜单的全屏无扰模式。
|
||||||
|
|
||||||
|
这个编辑器还在右边有个缩略地图,这在长文件中导航非常有用。应用程序为多种编程语言提供多种常用函数的片段,这使得它对于开发者非常有用。另一个精巧的功能是,无论你使用都是文本文档或者代码,都可以任意选择和替换。
|
||||||
|
|
||||||
|
![如果你不喜欢Sublime的Charcoal外观,你可以选择它包含的其它22种主题。](http://www.linuxvoice.com/wp-content/uploads/2014/08/sublime-web.png)
|
||||||
|
|
||||||
|
*如果你不喜欢Sublime的Charcoal外观,你可以选择它包含的其它22种主题。*
|
||||||
|
|
||||||
|
#### UltraEdit: 3/5 ####
|
||||||
|
|
||||||
|
UltraEdit在界面的顶部和底部加载了多种工具栏。加上切换文档的选项卡、两边的面板,以及分隔区域,使得只剩下一点空间给编辑窗口。
|
||||||
|
|
||||||
|
使用HTML的网络开发者有很多唾手可得的帮助。你可以通过FTP和SFTP访问远程文件。高级功能,例如记录一个宏以及比较文件,也简单易用。
|
||||||
|
|
||||||
|
使用应用程序的偏好设置窗口,你可以调整应用程序的多个方面,包括颜色主题和类似语法高亮的其它功能。
|
||||||
|
|
||||||
|
![UltraEdit的用户界面是高度可配置的 — 你可以像改变其它许多方面那样简单的自定义工具栏和菜单的布局。](http://www.linuxvoice.com/wp-content/uploads/2014/08/ultraedit-web.png)
|
||||||
|
|
||||||
|
*UltraEdit的用户界面是高度可配置的 — 你可以像改变其它许多方面那样简单的自定义工具栏和菜单的布局。*
|
||||||
|
|
||||||
|
#### jEdit: 3/5 ####
|
||||||
|
|
||||||
|
在可用性方面,首先一个不好就是jEdit不能在基于RPM的发行版上安装。导航编辑器需要一些时间来适应,因为它的菜单和其它流行的应用程序顺序不同,而且有些普通桌面用户不熟悉的名字。但是,该应用程序有详细的内部帮助,这有利于缓解学习曲线。
|
||||||
|
|
||||||
|
jEdit会高亮你所在的当前行,并使你能以多种查看方式分隔窗口。你可以简单地从应用程序中安装和管理插件,除了使用完整的宏,jEdit也支持你快速记录一个临时的宏。
|
||||||
|
|
||||||
|
![由于它的Java基础,jEdit在任何桌面环境中都不能给人宾至如归的感觉](http://www.linuxvoice.com/wp-content/uploads/2014/08/jedit-web.png)
|
||||||
|
|
||||||
|
*由于它的Java基础,jEdit在任何桌面环境中都不能给人宾至如归的感觉*
|
||||||
|
|
||||||
|
### 可用性和支持 ###
|
||||||
|
|
||||||
|
在Gedit和Kate之间有很多相似性。两个应用程序都得益于他们各自的父项目,Gnome和KDE,捆绑在各种主流的发行版中。另外两个项目都是跨平台的,有Windows和Mac OS X版本以及原生的Linux版本。
|
||||||
|
|
||||||
|
Gedit托管在Gnome的网站上,并有一个简单的用户指南、关于多种插件的信息,以及包括邮件列表和IRC通道在内的常用联系方式。你也可以在其它基于Gnome的发行版,例如Ubuntu中找到使用信息。相似地,Kate得益于KDE的资源,并包括详细的用户信息以及邮件列表和IRC通道。你也可以从应用程序中获取相应的离线用户指南。
|
||||||
|
|
||||||
|
除了Linux,UltraEdit在Windows和Mac OS X中也可用,虽然在应用程序中并没有包括,但在启动时也有详细的用户指南。为了辅助用户的使用,UltraEdit保存了一个常见问题的数据库,一系列关于多种特定功能的详细介绍,用户还可以在论坛版块彼此帮助。另外,付费用户也可以通过邮件从开发者中获取支持。
|
||||||
|
|
||||||
|
Sublime支持一样多的平台,但是你需要单独为每种平台购买许可证。开发者通过博客让用户了解正在进行的开发,并积极参加它的论坛。这个项目支持设施的亮点是提供免费的详细教程和视频课程。Sublime非常漂亮。
|
||||||
|
|
||||||
|
由于jEdit是用java编写的,所以它在多种平台中都可用。在它的网站上你可以找到一个详细的用户指南以及一些插件帮助文档的链接。然而,这里没有能使用户和其他用户或者开发者交流的途径。
|
||||||
|
|
||||||
|
**评分:**
|
||||||
|
|
||||||
|
- Gedit:4/5
|
||||||
|
- Kate:4/5
|
||||||
|
- Sublime:5/5
|
||||||
|
- UltraEdit:3/5
|
||||||
|
- jEdit:2/5
|
||||||
|
|
||||||
|
### 附加组件和插件 ###
|
||||||
|
|
||||||
|
不同的用户有不同的需求,一个简单的轻量级应用程序只能做到这么多。这就是为什么需要插件的原因。应用程序依赖于这些小部件来扩展它们的功能集并让更多的用户使用。
|
||||||
|
|
||||||
|
UltraEdit是一个例外。它没有第三方插件,但开发者将例如HtmlTidy这样的第三方工具集成到了UltraEdit。
|
||||||
|
|
||||||
|
Gedit附带了好多已安装的插件,你可以下载更多的更多gedit插件包。基于和Gedit版本的兼容性,项目网站也有到多个第三方插件的链接。
|
||||||
|
|
||||||
|
三个对程序员非常有用的插件是:Code Comment、在底部面板增加一个终端的Terminal Plugin以及Session Saver。当你用多个文件开发项目的时候Session Saver相当有用。你可以在选项卡中打开文件,保存会话,你可以用一键恢复,就可以按照你保存时的选项卡顺序打开所有的文件。
|
||||||
|
|
||||||
|
类似的,你可以通过用内部的插件管理器增加插件来扩展Kate。除了令人映像深刻的项目插件,一些开发者使用的插件包括嵌入式终端,它能编译和调试代码,以及对数据库执行SQL查询。
|
||||||
|
|
||||||
|
Sublime的插件是用Python写的,文本编辑器包括了一个类似于apt-get,能使用户查找,安装,升级和移除插件包的名为Package Control的工具。通过插件,你可以在Sublime中使用Git版本控制,以及美化JavaScript代码的JSLint工具。Sublime Linter能指出你代码中的错误,是编码人员必备的插件。
|
||||||
|
|
||||||
|
jEdit拥有最令人印象深刻的插件设施。该应用有超过200个插件,可以在它们自己的专用网站中浏览。网站通过不同的类型列出了插件,例如文件管理,版本控制,文本等。你可以在每个类型下找到很多的插件。
|
||||||
|
|
||||||
|
一些最好的插件是Android插件,它们提供了和Android项目协同工作的工具;你可以使用TomcatSwitch插件创建和控制外部Jakarta Tomcat服务器进程;以及类似于Vi功能的Vimulator插件。你可以通过使用jEdit的插件管理器安装这些插件。
|
||||||
|
|
||||||
|
**评分:**
|
||||||
|
|
||||||
|
- Gedit:3/5
|
||||||
|
- Kate:4/5
|
||||||
|
- Sublime:4/5
|
||||||
|
- UltraEdit:1/5
|
||||||
|
- jEdit:5/5
|
||||||
|
|
||||||
|
### 纯文本编辑 ###
|
||||||
|
|
||||||
|
尽管它们强大的额外功能甚至可能会取代几种完全成熟的应用程序,有时候可能只需要使用这些庞大的文本编辑器读、写或者编辑简单的纯文本。虽然你可以使用它们中的任何一个输入文本,我们通过普通文本编辑的方便性评价它们。
|
||||||
|
|
||||||
|
Gnome的默认文本编辑器Gedit,支持取消和重做机制以及搜索和替换。它可以对多种语言进行拼写检查,并能通过使用Gnome GVFS库访问和编辑远程文件。
|
||||||
|
|
||||||
|
你也可以使用Kate进行拼写检查,它也可以让你对任何高亮文本进行Google搜索。它还有一个能可视化告知用户文件中更改过但没有保存的行的行修改系统。另外,它通过允许用户在文件中使用书签简化长文档的导航。
|
||||||
|
|
||||||
|
Sublime有很多可选择的编辑命令,例如缩进文本和格式化段落。它的自动保存功能帮助防止用户丢失他们的更改。高级用户还会喜欢基于正则表达式的递归查找和替换功能,以及选择多个不连续的文本块并执行统一操作。
|
||||||
|
|
||||||
|
UltraEdit也允许用户在查找和替换功能中使用正则表达式,并能通过FTP编辑远程文件。
|
||||||
|
|
||||||
|
JEdit一个独特的功能是它支持被称为寄存器的不限数目的剪切板。你可以复制文本片段到这些寄存器中,在编辑会话过程中都可用。
|
||||||
|
|
||||||
|
**评分:**
|
||||||
|
|
||||||
|
- Gedit:4/5
|
||||||
|
- Kate:5/5
|
||||||
|
- Sublime:5/5
|
||||||
|
- UltraEdit:4/5
|
||||||
|
- jEdit:4/5
|
||||||
|
|
||||||
|
### 我们的评比 ###
|
||||||
|
|
||||||
|
在这里的所有编辑器都足以替换你已有的文本编辑器,来编辑文本和调整配置文件。事实上,没准它们会组合起来作为你的集成开发环境。这些应用程序都有各种各样功能,它们的开发者不会考虑剥离功能,而是增加越来越多的功能。
|
||||||
|
|
||||||
|
jEdit排在这次测试的最后面。因为它不仅坚持使用专有的Oracle Java运行时环境,不能在你的Fedora机器上安装,而且开发者并不积极和用户交互。
|
||||||
|
|
||||||
|
UltraEdit做的稍微好一点。这个商业专用工具专注于网络开发者,不为非开发者的高级用户提供任何功能,使得它不值得推荐为免费软件的替代品。
|
||||||
|
|
||||||
|
排在第三的是Gedit。作为Gnome的默认编辑器,它没有任何内在的问题,但尽管有很多积极的方面,它还是略微被Sublime和Kate超越。开诚布公地说,Kate是比Gedit更通用的编辑器,甚至考虑到他们的插件系统,评分也优于Gnome的默认编辑器。
|
||||||
|
|
||||||
|
Sublime和Kate都相当好。他们在我们的大多数测试中表现同样出色。Kate由于不支持宏而落后于Sublime,但键盘友好和能简单定义自定义键绑定又使Kate找回优势。
|
||||||
|
|
||||||
|
Kate成功的原因可以归结为它通过最小化学习曲线提供了最大化的功能。尽管使用它吧,不仅作为简单文本编辑器使用,或者容易使用语法高亮编辑配置文件,甚至得益于其项目管理能力能使用它协作一个复杂的编程项目。
|
||||||
|
|
||||||
|
我们不是选择Kate去替换一个类似“[XX,在这里插入你最喜欢的专业工具]”的全面的集成开发环境。但是它是一个专业工具理想的、全面的、以及完美的垫脚石。
|
||||||
|
|
||||||
|
Kate为能快速响应你的需要而设计,它的界面并不会使你茫然,并且和那些过于复杂的应用一样的有用。
|
||||||
|
|
||||||
|
### 1st Kate ###
|
||||||
|
|
||||||
|
- Licence LGPL/GPL Version 3.11
|
||||||
|
- www.kate-editor.org
|
||||||
|
- 拥有超能力,态度温和的文本编辑器。
|
||||||
|
- Kate是KDE项目中最有用的应用程序之一。
|
||||||
|
|
||||||
|
### 2nd Sublime Text ###
|
||||||
|
|
||||||
|
- Licence 专利 Version 2.0.2
|
||||||
|
- www.sublimetext.com
|
||||||
|
- 值得你每分钱的专业文本编辑器 - 简单易用,功能全面而且看起来很棒。
|
||||||
|
|
||||||
|
### 3rd Gedit ###
|
||||||
|
|
||||||
|
- Licence GPL Version 3.10
|
||||||
|
- http://projects.gnome.org/gedit
|
||||||
|
- 在Gnome中就用它吧。这是一个奇妙的文本编辑器,确实令人钦佩的工作,但这里的竞争实在太大了。
|
||||||
|
|
||||||
|
### 4th UltraEdit ###
|
||||||
|
|
||||||
|
- Licence Proprietary Version 4.1.0.4
|
||||||
|
- www.ultraedit.com
|
||||||
|
- 关注于为网络开发者提供各种便利,而不为普通用户提供任何特殊功能。
|
||||||
|
|
||||||
|
### 5th jEdit ###
|
||||||
|
|
||||||
|
- Licence GPL Version 5.1.0
|
||||||
|
- www.jedit.org
|
||||||
|
- 缺乏支持,不支持Fedora,缺乏好看的界面,jEdit被贬低到最后。
|
||||||
|
|
||||||
|
### 你也许希望尝试… ###
|
||||||
|
|
||||||
|
随你发行版发布的默认文本编辑器也能帮助你一些高级任务。例如KDE的KWrite和Raspbian的Nano。得益于KDE的katepart组件,KWrite继承了一些Kate的功能,得益于在树莓派上的可用性,Nano也开始重现风头。
|
||||||
|
|
||||||
|
如果你希望跟随Linux大师的脚步,你总是可以尝试高大上的文本编辑器Emacs和Vim。想尝试Vim强大的用户首先可以考虑gVim,它通过图形界面展现了Vim的强大。
|
||||||
|
|
||||||
|
除了jEdit和Kate,这里还有其他模仿Emacs和Vim之类的旧式高级编辑器的编辑器,比如JED 编辑器和Joe's Own Editor,这两者都有Emacs的模拟模式。另一方面,如果你在寻找轻量级的代码编辑器,可以看看Bluefish和Geany。他们的存在是为了填补文本编辑器和全面集成的开发平台之间的空隙。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.linuxvoice.com/text-editors/
|
||||||
|
|
||||||
|
作者:[Ben Everard][a]
|
||||||
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
|
校对:[royaso](https://github.com/royaso),[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.linuxvoice.com/author/ben_everard/
|
@ -0,0 +1,136 @@
|
|||||||
|
又一波你可能不知道的 Linux 命令行网络监控工具
|
||||||
|
===============================================================================
|
||||||
|
|
||||||
|
对任何规模的业务来说,网络监控工具都是一个重要的功能。网络监控的目标可能千差万别。比如,监控活动的目标可以是保证长期的网络服务、安全保护、对性能进行排查、网络使用统计等。由于它的目标不同,网络监控器使用很多不同的方式来完成任务。比如对包层面的嗅探,对数据流层面的统计数据,向网络中注入探测的流量,分析服务器日志等。
|
||||||
|
|
||||||
|
尽管有许多专用的网络监控系统可以365天24小时监控,但您依旧可以在特定的情况下使用命令行式的网络监控器,某些命令行式的网络监控器在某方面很有用。如果您是系统管理员,那您就应该有亲身使用一些知名的命令行式网络监控器的经历。这里有一份**Linux上流行且实用的网络监控器**列表。
|
||||||
|
|
||||||
|
### 包层面的嗅探器 ###
|
||||||
|
|
||||||
|
在这个类别下,监控工具在链路上捕捉独立的包,分析它们的内容,展示解码后的内容或者包层面的统计数据。这些工具在最底层对网络进行监控、管理,同样的也能进行最细粒度的监控,其代价是影响网络I/O和分析的过程。
|
||||||
|
|
||||||
|
1. **dhcpdump**:一个命令行式的DHCP流量嗅探工具,捕捉DHCP的请求/回复流量,并以用户友好的方式显示解码的DHCP协议消息。这是一款排查DHCP相关故障的实用工具。
|
||||||
|
|
||||||
|
2. **[dsniff][1]**:一个基于命令行的嗅探、伪造和劫持的工具合集,被设计用于网络审查和渗透测试。它可以嗅探多种信息,比如密码、NSF流量(LCTT 译注:此处疑为 NFS 流量)、email消息、网络地址等。
|
||||||
|
|
||||||
|
3. **[httpry][2]**:一个HTTP报文嗅探器,用于捕获、解码HTTP请求和回复报文,并以用户友好的方式显示这些信息。(LCTT 译注:[延伸阅读](https://linux.cn/article-4148-1.html)。 )
|
||||||
|
|
||||||
|
4. **IPTraf**:基于命令行的网络统计数据查看器。它实时显示包层面、连接层面、接口层面、协议层面的报文/字节数。抓包过程由协议过滤器控制,且操作过程全部是菜单驱动的。(LCTT 译注:[延伸阅读](https://linux.cn/article-5430-1.html)。)
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7519/16055246118_8ea182b413_c.jpg)
|
||||||
|
|
||||||
|
5. **[mysql-sniffer][3]**:一个用于抓取、解码MySQL请求相关的数据包的工具。它以可读的方式显示最频繁或全部的请求。
|
||||||
|
|
||||||
|
6. **[ngrep][4]**:在网络报文中执行grep。它能实时抓取报文,并用正则表达式或十六进制表达式的方式匹配(过滤)报文。它是一个可以对异常流量进行检测、存储或者对实时流中特定模式报文进行抓取的实用工具。
|
||||||
|
|
||||||
|
7. **[p0f][5]**:一个被动的基于包嗅探的指纹采集工具,可以可靠地识别操作系统、NAT或者代理设置、网络链路类型以及许多其它与活动的TCP连接相关的属性。
|
||||||
|
|
||||||
|
8. **pktstat**:一个命令行式的工具,通过实时分析报文,显示连接带宽使用情况以及相关的协议(例如,HTTP GET/POST、FTP、X11)等描述信息。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7477/16048970999_be60f74952_b.jpg)
|
||||||
|
|
||||||
|
9. **Snort**:一个入侵检测和预防工具,通过规则驱动的协议分析和内容匹配,来检测/预防活跃流量中各种各样的后门、僵尸网络、网络钓鱼、间谍软件攻击。
|
||||||
|
|
||||||
|
10. **tcpdump**:一个命令行的嗅探工具,可以基于过滤表达式抓取网络中的报文,分析报文,并且在包层面输出报文内容以便于包层面的分析。他在许多网络相关的错误排查、网络程序debug、或[安全][6]监测方面应用广泛。
|
||||||
|
|
||||||
|
11. **tshark**:一个与Wireshark窗口程序一起使用的命令行式的嗅探工具。它能捕捉、解码网络上的实时报文,并能以用户友好的方式显示其内容。
|
||||||
|
|
||||||
|
### 流/进程/接口层面的监控 ###
|
||||||
|
|
||||||
|
在这个分类中,网络监控器通过把流量按照流、相关进程或接口分类,收集每个流、每个进程、每个接口的统计数据。其信息的来源可以是libpcap抓包库或者sysfs内核虚拟文件系统。这些工具的监控成本很低,但是缺乏包层面的检视能力。
|
||||||
|
|
||||||
|
12. **bmon**:一个基于命令行的带宽监测工具,可以显示各种接口相关的信息,不但包括接收/发送的总量/平均值统计数据,而且拥有历史带宽使用视图。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8580/16234265932_87f20c5d17_b.jpg)
|
||||||
|
|
||||||
|
13. **[iftop][7]**:一个带宽使用监测工具,可以实时显示某个网络连接的带宽使用情况。它对所有带宽使用情况排序并通过ncurses的接口来进行可视化。他可以方便的监控哪个连接消耗了最多的带宽。(LCTT 译注:[延伸阅读](https://linux.cn/article-1843-1.html)。)
|
||||||
|
|
||||||
|
14. **nethogs**:一个基于ncurses显示的进程监控工具,提供进程相关的实时的上行/下行带宽使用信息。它对检测占用大量带宽的进程很有用。(LCTT 译注:[延伸阅读](https://linux.cn/article-2808-1.html)。)
|
||||||
|
|
||||||
|
15. **netstat**:一个显示许多TCP/UDP的网络堆栈的统计信息的工具。诸如打开的TCP/UDP连接书、网络接口发送/接收、路由表、协议/套接字的统计信息和属性。当您诊断与网络堆栈相关的性能、资源使用时它很有用。
|
||||||
|
|
||||||
|
16. **[speedometer][8]**:一个可视化某个接口发送/接收的带宽使用的历史趋势,并且基于ncurses的条状图进行显示的终端工具。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7485/16048971069_31dd573a4f_c.jpg)
|
||||||
|
|
||||||
|
17. **[sysdig][9]**:一个可以通过统一的界面对各个Linux子系统进行系统级综合性调试的工具。它的网络监控模块可以监控在线或离线、许多进程/主机相关的网络统计数据,例如带宽、连接/请求数等。(LCTT 译注:[延伸阅读](https://linux.cn/article-4341-1.html)。)
|
||||||
|
|
||||||
|
18. **tcptrack**:一个TCP连接监控工具,可以显示活动的TCP连接,包括源/目的IP地址/端口、TCP状态、带宽使用等。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7507/16047703080_5fdda2e811_b.jpg)
|
||||||
|
|
||||||
|
19. **vnStat**:一个存储并显示每个接口的历史接收/发送带宽视图(例如,当前、每日、每月)的流量监控器。作为一个后台守护进程,它收集并存储统计数据,包括接口带宽使用率和传输字节总数。(LCTT 译注:[延伸阅读](https://linux.cn/article-5256-1.html)。)
|
||||||
|
|
||||||
|
### 主动网络监控器 ###
|
||||||
|
|
||||||
|
不同于前面提到的被动的监听工具,这个类别的工具们在监听时会主动的“注入”探测内容到网络中,并且会收集相应的反应。监听目标包括路由路径、可供使用的带宽、丢包率、延时、抖动(jitter)、系统设置或者缺陷等。
|
||||||
|
|
||||||
|
20. **[dnsyo][10]**:一个DNS检测工具,能够管理跨越多达1500个不同网络的开放解析器的DNS查询。它在您检查DNS传播或排查DNS设置的时候很有用。
|
||||||
|
|
||||||
|
21. **[iperf][11]**:一个TCP/UDP带宽测量工具,能够测量两个端点间最大可用带宽。它通过在两个主机间单向或双向的输出TCP/UDP探测流量来测量可用的带宽。它在监测网络容量、调谐网络协议栈参数时很有用。一个叫做[netperf][12]的变种拥有更多的功能及更好的统计数据。
|
||||||
|
|
||||||
|
22. **[netcat][13]/socat**:通用的网络调试工具,可以对TCP/UDP套接字进行读、写或监听。它通常和其他的程序或脚本结合起来在后端对网络传输或端口进行监听。(LCTT 译注:[延伸阅读](https://linux.cn/article-1171-1.html)。)
|
||||||
|
|
||||||
|
23. **nmap**:一个命令行的端口扫描和网络发现工具。它依赖于若干基于TCP/UDP的扫描技术来查找开放的端口、活动的主机或者在本地网络存在的操作系统。它在你审查本地主机漏洞或者建立维护所用的主机映射时很有用。[zmap][14]是一个类似的替代品,是一个用于互联网范围的扫描工具。(LCTT 译注:[延伸阅读](https://linux.cn/article-2561-1.html)。)
|
||||||
|
|
||||||
|
24. ping:一个常用的网络测试工具。通过交换ICMP的echo和reply报文来实现其功能。它在测量路由的RTT、丢包率以及检测远端系统防火墙规则时很有用。ping的变种有更漂亮的界面(例如,[noping][15])、多协议支持(例如,[hping][16])或者并行探测能力(例如,[fping][17])。(LCTT 译注:[延伸阅读](https://linux.cn/article-2303-1.html)。)
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7466/15612665344_a4bb665a5b_c.jpg)
|
||||||
|
|
||||||
|
25. **[sprobe][18]**:一个启发式推断本地主机和任意远端IP地址之间的网络带宽瓶颈的命令行工具。它使用TCP三次握手机制来评估带宽的瓶颈。它在检测大范围网络性能和路由相关的问题时很有用。
|
||||||
|
|
||||||
|
26. **traceroute**:一个能发现从本地到远端主机的第三层路由/转发路径的网络发现工具。它发送限制了TTL的探测报文,收集中间路由的ICMP反馈信息。它在排查低速网络连接或者路由相关的问题时很有用。traceroute的变种有更好的RTT统计功能(例如,[mtr][19])。
|
||||||
|
|
||||||
|
### 应用日志解析器 ###
|
||||||
|
|
||||||
|
在这个类别下的网络监测器把特定的服务器应用程序作为目标(例如,web服务器或者数据库服务器)。由服务器程序产生或消耗的网络流量通过它的日志被分析和监测。不像前面提到的网络层的监控器,这个类别的工具能够在应用层面分析和监控网络流量。
|
||||||
|
|
||||||
|
27. **[GoAccess][20]**:一个针对Apache和Nginx服务器流量的交互式查看器。基于对获取到的日志的分析,它能展示包括日访问量、最多请求、客户端操作系统、客户端位置、客户端浏览器等在内的多个实时的统计信息,并以滚动方式显示。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7518/16209185266_da6c5c56eb_c.jpg)
|
||||||
|
|
||||||
|
28. **[mtop][21]**:一个面向MySQL/MariaDB服务器的命令行监控器,它可以将成本最大的查询和当前数据库服务器负载以可视化的方式显示出来。它在您优化MySQL服务器性能、调谐服务器参数时很有用。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7472/16047570248_bc996795f2_c.jpg)
|
||||||
|
|
||||||
|
29. **[ngxtop][22]**:一个面向Nginx和Apache服务器的流量监测工具,能够以类似top指令的方式可视化的显示Web服务器的流量。它解析web服务器的查询日志文件并收集某个目的地或请求的流量统计信息。
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
在这篇文章中,我展示了许多命令行式监测工具,从最底层的包层面的监控器到最高层应用程序层面的网络监控器。了解那个工具的作用是一回事,选择哪个工具使用又是另外一回事。单一的一个工具不能作为您每天使用的通用的解决方案。一个好的系统管理员应该能决定哪个工具更适合当前的环境。希望这个列表对此有所帮助。
|
||||||
|
|
||||||
|
欢迎您通过回复来改进这个列表的内容!
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/useful-command-line-network-monitors-linux.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/nanni
|
||||||
|
[1]:http://www.monkey.org/~dugsong/dsniff/
|
||||||
|
[2]:http://xmodulo.com/monitor-http-traffic-command-line-linux.html
|
||||||
|
[3]:https://github.com/zorkian/mysql-sniffer
|
||||||
|
[4]:http://ngrep.sourceforge.net/
|
||||||
|
[5]:http://lcamtuf.coredump.cx/p0f3/
|
||||||
|
[6]:http://xmodulo.com/recommend/firewallbook
|
||||||
|
[7]:http://xmodulo.com/how-to-install-iftop-on-linux.html
|
||||||
|
[8]:https://excess.org/speedometer/
|
||||||
|
[9]:http://xmodulo.com/monitor-troubleshoot-linux-server-sysdig.html
|
||||||
|
[10]:http://xmodulo.com/check-dns-propagation-linux.html
|
||||||
|
[11]:https://iperf.fr/
|
||||||
|
[12]:http://www.netperf.org/netperf/
|
||||||
|
[13]:http://xmodulo.com/useful-netcat-examples-linux.html
|
||||||
|
[14]:https://zmap.io/
|
||||||
|
[15]:http://noping.cc/
|
||||||
|
[16]:http://www.hping.org/
|
||||||
|
[17]:http://fping.org/
|
||||||
|
[18]:http://sprobe.cs.washington.edu/
|
||||||
|
[19]:http://xmodulo.com/better-alternatives-basic-command-line-utilities.html#mtr_link
|
||||||
|
[20]:http://goaccess.io/
|
||||||
|
[21]:http://mtop.sourceforge.net/
|
||||||
|
[22]:http://xmodulo.com/monitor-nginx-web-server-command-line-real-time.html
|
@ -0,0 +1,58 @@
|
|||||||
|
‘Unity Greeter Badges’:将丢失的会话图标带回Ubuntu登录屏幕
|
||||||
|
================================================================================
|
||||||
|
![](http://www.omgubuntu.co.uk/wp-content/uploads/2015/01/unity-greeter-badges-750x321.jpg)
|
||||||
|
|
||||||
|
新出现在**Ubuntu 15.04中的一个软件包解决了我对Unity 欢迎屏的微词:像Cinnamon这样的其它Linux桌面会话没有徽章图标。**
|
||||||
|
|
||||||
|
我知道这有点吹毛求疵了;这只是对大多数人而言几乎毫无影响的视觉瑕疵罢了。但是这种不一致性时时刻刻缠绕着我,让我不胜其烦,因为Ubuntu的一些会话带有徽章图标,包括Unity、GNOME和KDE。而剩下的其它桌面环境,包括它自己的一些旁系产品,像Xubuntu,只会在会话切换列表和主用户界面显示了一个不能再简单的白点。
|
||||||
|
|
||||||
|
这些点点们造成的这种不一致性刺激着我的神经,即使它只是稍纵即逝,但这种刺激不仅仅来自设计,也来自可用性方面。标牌式的标志符号对于让我们知道我们即将登陆到哪个会话很有帮助。
|
||||||
|
|
||||||
|
例如,你能告诉我们这个是个什么会话呢?
|
||||||
|
|
||||||
|
![](http://www.omgubuntu.co.uk/wp-content/uploads/2015/01/what-session-is-this-750x247.jpg)
|
||||||
|
|
||||||
|
Budgie? 也许是 MATE? 也能是 Cinnamon……我必须点开它才能知道。
|
||||||
|
|
||||||
|
没有必要这样做啊。构建Unity Greeter,就是为了让桌面环境开发者能够部署徽章到欢迎屏幕中(有些确实这样做了)。但在许多情况下,像MATE,它的包来自上游的Debian,想要移植一个“Ubuntu专用的补丁包”不太可取,也不太可能。
|
||||||
|
|
||||||
|
### 一个解决方案出炉了 ###
|
||||||
|
|
||||||
|
一位有经验的Debian维护者[Doug Torrance][1]有了修复该可用性瑕疵的解决方案。与其依赖桌面制造者自己来添加品牌式徽章到他们的包中,与其给Ubuntu增加维护它的责任重担,Torrance还不如自己创建了一个独立的‘unity-greeter-badges’包来收容它们。
|
||||||
|
|
||||||
|
承担起了直接提供会话标志的假定责任后,该包确保能同时迎合新旧窗口管理器、会话和桌面。
|
||||||
|
|
||||||
|
在30个左右的桌面环境列表中,它为以下桌面捆绑了新的会话徽章:
|
||||||
|
|
||||||
|
- Xubuntu
|
||||||
|
- Cinnamon
|
||||||
|
- MATE
|
||||||
|
- Cairo-Dock
|
||||||
|
- Xmonad
|
||||||
|
- Awesome
|
||||||
|
- OpenBox
|
||||||
|
- Pantheon
|
||||||
|
|
||||||
|
最重要的是,‘**Unity-Greeter-Badges**’已经被Ubuntu 15.04收录进去。这就意味着Torrance的包将可以直接安装,不需要PPA,也不需要下载。没有像Unity Greeter一样成为核心包的一部分,它可以以更高效和更及时的方式更新新的图标。
|
||||||
|
|
||||||
|
如果你真运行着Ubuntu 15.04,在不久的将来,你就可以从软件中心获取并安装该包了。
|
||||||
|
|
||||||
|
不想等到15.04?Torrance已经为Ubuntu 14.04和Ubuntu 14.10用户做了个.deb安装器。
|
||||||
|
|
||||||
|
- [下载用于Ubuntu 14.04的unity-greeter-badges][2]
|
||||||
|
- [下载用于Ubuntu 14.10的unity-greeter-badges][3]
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.omgubuntu.co.uk/2015/01/unity-greeter-badges-brings-missing-session-icons-ubuntu-login-screen
|
||||||
|
|
||||||
|
作者:[Joey-Elijah Sneddon][a]
|
||||||
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:https://plus.google.com/117485690627814051450/?rel=author
|
||||||
|
[1]:https://launchpad.net/~profzoom
|
||||||
|
[2]:https://launchpad.net/~profzoom/+archive/ubuntu/misc/+files/unity-greeter-badges_0.1-0ubuntu1%7E201412111501%7Eubuntu14.04.1_all.deb
|
||||||
|
[3]:https://launchpad.net/~profzoom/+archive/ubuntu/misc/+files/unity-greeter-badges_0.1-0ubuntu1%7E201412111501%7Eubuntu14.10.1_all.deb
|
@ -0,0 +1,73 @@
|
|||||||
|
如何在Linux下创建一个不可变更的文件
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
假如你想对Linux中的一些重要文件做写保护,这样它们就不能被删除或者被篡改成之前的版本或者其他东西,或者在其他情况下,你可能想避免某些配置文件被软件自动修改。使用`chown`和`chmod`命令修改文件的归属关系或者权限位是处理这种情况的一个解决方法,但这并不完美,因为这样无法避免有root权限的操作。这时`chattr`就派上用场了。
|
||||||
|
|
||||||
|
`chattr`是一个可以设置或取消文件的标志位的Linux命令,它和标准的文件权限(读、写、执行)是分离的。与此相关的另一个命令是`lsattr`,它可以显示文件的哪些标志位被设置上了。最初只有EXT文件系统(EXT2/3/4)支持`chattr`和`lsattr`所管理的标志位,但现在很多其他的原生的Linux文件系统都支持了,比如XFS、Btrfs、ReiserFS等等。
|
||||||
|
|
||||||
|
在这个教程中,我会示范如果使用`chattr`来让Linux中的文件不可变更。
|
||||||
|
|
||||||
|
`chattr`和`lsattr`命令是e2fsprogs包的一部分,它在所有现代Linux发行版都预装了。
|
||||||
|
|
||||||
|
下面是`chattr`的基本语法。
|
||||||
|
|
||||||
|
$ chattr [-RVf] [操作符][标志位] 文件...
|
||||||
|
|
||||||
|
其中操作符可以是“+”(把选定的标志位添加到标志位列表)、“-”(从标志位列表中移除选定的标志位)、或者“=”(强制使用选定的标志位)。
|
||||||
|
|
||||||
|
下面是一些可用的标志位。
|
||||||
|
|
||||||
|
- **a**: 只能以追加模式打开。
|
||||||
|
- **A**: 不能更新atime(文件访问时间)。
|
||||||
|
- **c**: 当被写入磁盘时被自动压缩。
|
||||||
|
- **C**: 关掉“写时复制”。
|
||||||
|
- **i**: 不可变更。
|
||||||
|
- **s**: 通过自动归零来安全删除。(LCTT 译注:一般情况文件被删后内容不会被修改,改标志位会使得文件被删后原有内容被“0”取代)
|
||||||
|
|
||||||
|
### “不可变更”标志位 ###
|
||||||
|
|
||||||
|
为了让一个文件不可变更,你需要按照如下方法为这个文件添加“不可变更”标志位。例如,对/etc/passwd文件做写保护:
|
||||||
|
|
||||||
|
$ sudo chattr +i /etc/passwd
|
||||||
|
|
||||||
|
注意设置或取消一个文件的“不可变更”标志位是需要root用户权限的。现在检查该文件“不可变更”标志位是否被添加上了。
|
||||||
|
|
||||||
|
$ lsattr /etc/passwd
|
||||||
|
|
||||||
|
一旦文件被设置为不可变更,任何用户都将无法修改该文件。即使是root用户也不可以修改、删除、覆盖、移动或者重命名这个文件。如果你想再次修改这个文件,需要先把“不可变更”标志位取消了。
|
||||||
|
|
||||||
|
用如下命令取消“不可变更”标志位:
|
||||||
|
|
||||||
|
$ sudo chattr -i /etc/passwd
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8613/16152651317_076a65cf50_b.jpg)
|
||||||
|
|
||||||
|
如果你想让一个目录(比如/etc)连同它下边的所有内容不可变更,使用“-R”选项:
|
||||||
|
|
||||||
|
$ sudo chattr -R +i /etc
|
||||||
|
|
||||||
|
### “只可追加”标志位 ###
|
||||||
|
|
||||||
|
另一个有用的的标志位是“只可追加”,它只允许文件内容被追加的方式修改。你不能覆盖或者删除一个设置了“只可追加”标志位的文件。这个标志位在你想避免日志文件被意外清理掉的情况很有用。
|
||||||
|
|
||||||
|
和“不可变更”标志位类似,你可以使用如下命令让文件变成“只可追加”模式:
|
||||||
|
|
||||||
|
$ sudo chattr +a /var/log/syslog
|
||||||
|
|
||||||
|
注意当你复制一个“不可变更”或者“只可追加”的文件到其他地方后,新文件不会保留这些标志位!
|
||||||
|
|
||||||
|
### 结论 ###
|
||||||
|
|
||||||
|
在这个教程中,我展示了如何使用`chattr`和`lsattr`命令来管理额外的文件标志位,来避免文件被篡改(意外或者其他情况)的方法。注意你不能将`chattr`作为一个安全措施,因为“不可变更”标志位可以很容易被取消掉。解决这个问题的一个可能的方式是限制`chattr`命令自身的可用性,或者去掉CAP_LINUX_IMMUTABLE内核权能标志。关于`chattr`以及可用的标志位的更多细节,请参考它的man手册。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/make-file-immutable-linux.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[goreliu](https://github.com/goreliu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/nanni
|
@ -1,171 +1,172 @@
|
|||||||
Inxi: Find System And Hardware Information On Linux
|
Inxi:获取Linux的系统和硬件信息
|
||||||
================================================================================
|
================================================================================
|
||||||
We already have shown different [applications][1] and ways to find the system and hardware information on Linux. In that series, today we will see how to find such details using **inxi**. It can be used for forum technical support, as a debugging tool, to quickly ascertain user system configuration and hardware.
|
|
||||||
|
我们已经展示了一些不同的[应用程序][1]和方法来获取Linux的系统和硬件信息。在这一系列里,我们将看到如何使用**inxi**来获取这些详情信息。在论坛技术支持中,它可以作为调试工具,迅速确定用户的系统配置和硬件信息。
|
||||||
**Inxi** is a command line tool that can be used to find the complete system and hardware details such as;
|
|
||||||
|
**Inxi**是一个可以获取完整的系统和硬件详情信息的命令行工具,内容包括:
|
||||||
- Hardware,
|
|
||||||
- CPU,
|
- 硬件
|
||||||
- Drivers,
|
- CPU
|
||||||
- Xorg,
|
- 磁盘驱动器
|
||||||
- Desktop,
|
- Xorg
|
||||||
- Kernel,
|
- 桌面环境
|
||||||
- GCC version,
|
- 内核
|
||||||
- Processes,
|
- GCC版本
|
||||||
- RAM usage,
|
- 进程
|
||||||
- and other useful information.
|
- 内存占用
|
||||||
|
- 和其他有用的信息
|
||||||
### Installation ###
|
|
||||||
|
### 安装方法 ###
|
||||||
Inxi is available in the default repositories of most modern GNU/Linux operating systems. So, we can simply install it by running the following commands.
|
|
||||||
|
Inxi在多数现代GNU/Linux操作系统的默认软件仓库中。所以我们可以简单地运行下列命令安装。
|
||||||
**On Debian based system:**
|
|
||||||
|
**在基于Debian的发行版:**
|
||||||
sudo apt-get install inxi
|
|
||||||
|
sudo apt-get install inxi
|
||||||
**On Fedora:**
|
|
||||||
|
**在Fedora:**
|
||||||
sudo yum install inxi
|
|
||||||
|
sudo yum install inxi
|
||||||
**On RHEL based systems:**
|
|
||||||
|
**在基于RHEL的发行版:**
|
||||||
Install EPEL repository:
|
|
||||||
|
安装EPEL软件仓库:
|
||||||
sudo yum install epel-release
|
|
||||||
|
sudo yum install epel-release
|
||||||
Then, install inxi using command:
|
|
||||||
|
然后使用如下命令安装inxi:
|
||||||
sudo yum install inxi
|
|
||||||
|
sudo yum install inxi
|
||||||
### Usage ###
|
|
||||||
|
### 使用方法 ###
|
||||||
To find the quick view of the system information, run the following command from Terminal.
|
|
||||||
|
在终端运行如下命令可以获取系统的概况信息。
|
||||||
inxi
|
|
||||||
|
inxi
|
||||||
**Sample output:**
|
|
||||||
|
**示例输出:**
|
||||||
CPU~Dual core Intel Core i3-2350M CPU (-HT-MCP-) clocked at Min:800.000Mhz Max:1200.000Mhz Kernel~3.13.0-45-generic x86_64 Up~6:41 Mem~1537.7/3861.3MB HDD~500.1GB(52.5% used) Procs~183 Client~Shell inxi~1.9.17
|
|
||||||
|
CPU~Dual core Intel Core i3-2350M CPU (-HT-MCP-) clocked at Min:800.000Mhz Max:1200.000Mhz Kernel~3.13.0-45-generic x86_64 Up~6:41 Mem~1537.7/3861.3MB HDD~500.1GB(52.5% used) Procs~183 Client~Shell inxi~1.9.17
|
||||||
Ofcourse, we can retrieve a particular hardware details. For example to retrieve the **Audio/Sound hardware details**, run the following command:
|
|
||||||
|
当然,我们可以获取一个特定硬件的详情信息。比如获取**声音/音频硬件详情信息**,可以运行如下命令:
|
||||||
inxi -A
|
|
||||||
|
inxi -A
|
||||||
**Sample output:**
|
|
||||||
|
**示例输出:**
|
||||||
Audio: Card: Intel 6 Series/C200 Series Family High Definition Audio Controller driver: snd_hda_intel
|
|
||||||
Sound: Advanced Linux Sound Architecture ver: k3.13.0-45-generic
|
Audio: Card: Intel 6 Series/C200 Series Family High Definition Audio Controller driver: snd_hda_intel
|
||||||
|
Sound: Advanced Linux Sound Architecture ver: k3.13.0-45-generic
|
||||||
Cool, isn’t it?
|
|
||||||
|
很酷是吧?
|
||||||
Likewise, you can retrieve the details of **Graphic card** information.
|
|
||||||
|
同样的,你可以获取**显卡**的详情信息。
|
||||||
inxi -G
|
|
||||||
|
inxi -G
|
||||||
**Sample output:**
|
|
||||||
|
**示例输出:**
|
||||||
Graphics: Card: Intel 2nd Generation Core Processor Family Integrated Graphics Controller
|
|
||||||
X.Org: 1.15.1 drivers: intel (unloaded: fbdev,vesa) Resolution: 1366x768@60.0hz
|
Graphics: Card: Intel 2nd Generation Core Processor Family Integrated Graphics Controller
|
||||||
GLX Renderer: Mesa DRI Intel Sandybridge Mobile GLX Version: 3.0 Mesa 10.3.0
|
X.Org: 1.15.1 drivers: intel (unloaded: fbdev,vesa) Resolution: 1366x768@60.0hz
|
||||||
|
GLX Renderer: Mesa DRI Intel Sandybridge Mobile GLX Version: 3.0 Mesa 10.3.0
|
||||||
What about harddisk information? That’s also possible. To view the full **harddisk** information, run the following command.
|
|
||||||
|
硬盘信息呢?也是可以的。运行如下命令来获取完整的**硬盘**信息。
|
||||||
inxi -D
|
|
||||||
|
inxi -D
|
||||||
**Sample Output:**
|
|
||||||
|
**示例输出:**
|
||||||
Drives: HDD Total Size: 500.1GB (52.5% used) 1: id: /dev/sda model: ST9601325BD size: 500.1GB
|
|
||||||
|
Drives: HDD Total Size: 500.1GB (52.5% used) 1: id: /dev/sda model: ST9601325BD size: 500.1GB
|
||||||
To display the Bios and Motherboard details:
|
|
||||||
|
显示Bios和主板详情信息:
|
||||||
inxi -M
|
|
||||||
|
inxi -M
|
||||||
**Sample output:**
|
|
||||||
|
**示例输出:**
|
||||||
Machine: System: Dell (portable) product: Inspiron N5050
|
|
||||||
Mobo: Dell model: 01HXXJ version: A05 Bios: Dell version: A05 date: 08/03/2012
|
Machine: System: Dell (portable) product: Inspiron N5050
|
||||||
|
Mobo: Dell model: 01HXXJ version: A05 Bios: Dell version: A05 date: 08/03/2012
|
||||||
Not only hardware details, it can also displays the **list of available repositories** in our system.
|
|
||||||
|
不仅是硬性详情信息,它也可以显示我们系统中的**可用软件仓库列表**。
|
||||||
inxi -r
|
|
||||||
|
inxi -r
|
||||||
**Sample output:**
|
|
||||||
|
**示例输出:**
|
||||||
Repos: Active apt sources in file: /etc/apt/sources.list
|
|
||||||
deb http://ubuntu.excellmedia.net/archive/ trusty main restricted
|
Repos: Active apt sources in file: /etc/apt/sources.list
|
||||||
deb-src http://ubuntu.excellmedia.net/archive/ trusty main restricted
|
deb http://ubuntu.excellmedia.net/archive/ trusty main restricted
|
||||||
deb http://ubuntu.excellmedia.net/archive/ trusty-updates main restricted
|
deb-src http://ubuntu.excellmedia.net/archive/ trusty main restricted
|
||||||
deb-src http://ubuntu.excellmedia.net/archive/ trusty-updates main restricted
|
deb http://ubuntu.excellmedia.net/archive/ trusty-updates main restricted
|
||||||
deb http://ubuntu.excellmedia.net/archive/ trusty universe
|
deb-src http://ubuntu.excellmedia.net/archive/ trusty-updates main restricted
|
||||||
.
|
deb http://ubuntu.excellmedia.net/archive/ trusty universe
|
||||||
.
|
.
|
||||||
Active apt sources in file: /etc/apt/sources.list.d/intellinuxgraphics.list
|
.
|
||||||
deb https://download.01.org/gfx/ubuntu/14.04/main trusty main #Intel Graphics drivers
|
Active apt sources in file: /etc/apt/sources.list.d/intellinuxgraphics.list
|
||||||
Active apt sources in file: /etc/apt/sources.list.d/linrunner-tlp-trusty.list
|
deb https://download.01.org/gfx/ubuntu/14.04/main trusty main #Intel Graphics drivers
|
||||||
Active apt sources in file: /etc/apt/sources.list.d/wseverin-ppa-trusty.list
|
Active apt sources in file: /etc/apt/sources.list.d/linrunner-tlp-trusty.list
|
||||||
deb http://ppa.launchpad.net/wseverin/ppa/ubuntu trusty main
|
Active apt sources in file: /etc/apt/sources.list.d/wseverin-ppa-trusty.list
|
||||||
|
deb http://ppa.launchpad.net/wseverin/ppa/ubuntu trusty main
|
||||||
Inxi will also display the Weather details of your location. Surprised? Yes, It should.
|
|
||||||
|
Inxi还可以显示你所在位置的天气信息。感到意外吗?是的,它可以。
|
||||||
inxi -W Erode,Tamilnadu
|
|
||||||
|
inxi -W Erode,Tamilnadu
|
||||||
Here **Erode** is the District and **Tamilnadu** is a state in India.
|
|
||||||
|
这里**Erode**是地区,**Tamilnadu**是印度的一个邦。
|
||||||
Sample output:
|
|
||||||
|
示例输出:
|
||||||
Weather: Conditions: 79 F (26 C) - Clear Time: February 4, 6:00 PM IST
|
|
||||||
|
Weather: Conditions: 79 F (26 C) - Clear Time: February 4, 6:00 PM IST
|
||||||
### Viewing Complete Hardware details ###
|
|
||||||
|
### 查看完整的硬件详情信息 ###
|
||||||
Tired of finding each hardware details? Well, you can list all details at once using command:
|
|
||||||
|
厌倦了逐一获取每种硬件的信息?你可以使用如下命令将所有信息一次列出:
|
||||||
inxi -F
|
|
||||||
|
inxi -F
|
||||||
**Sample output:**
|
|
||||||
|
**示例输出:**
|
||||||
System: Host: sk Kernel: 3.13.0-45-generic x86_64 (64 bit) Desktop: LXDE (Openbox 3.5.2) Distro: Ubuntu 14.04 trusty
|
|
||||||
Machine: System: Dell (portable) product: Inspiron N5050
|
System: Host: sk Kernel: 3.13.0-45-generic x86_64 (64 bit) Desktop: LXDE (Openbox 3.5.2) Distro: Ubuntu 14.04 trusty
|
||||||
Mobo: Dell model: 01HXXJ version: A05 Bios: Dell version: A05 date: 08/03/2012
|
Machine: System: Dell (portable) product: Inspiron N5050
|
||||||
CPU: Dual core Intel Core i3-2350M CPU (-HT-MCP-) cache: 3072 KB flags: (lm nx sse sse2 sse3 sse4_1 sse4_2 ssse3 vmx)
|
Mobo: Dell model: 01HXXJ version: A05 Bios: Dell version: A05 date: 08/03/2012
|
||||||
Clock Speeds: 1: 800.00 MHz 2: 1000.00 MHz 3: 800.00 MHz 4: 800.00 MHz
|
CPU: Dual core Intel Core i3-2350M CPU (-HT-MCP-) cache: 3072 KB flags: (lm nx sse sse2 sse3 sse4_1 sse4_2 ssse3 vmx)
|
||||||
Graphics: Card: Intel 2nd Generation Core Processor Family Integrated Graphics Controller
|
Clock Speeds: 1: 800.00 MHz 2: 1000.00 MHz 3: 800.00 MHz 4: 800.00 MHz
|
||||||
X.Org: 1.15.1 drivers: intel (unloaded: fbdev,vesa) Resolution: 1366x768@60.0hz
|
Graphics: Card: Intel 2nd Generation Core Processor Family Integrated Graphics Controller
|
||||||
GLX Renderer: Mesa DRI Intel Sandybridge Mobile GLX Version: 3.0 Mesa 10.3.0
|
X.Org: 1.15.1 drivers: intel (unloaded: fbdev,vesa) Resolution: 1366x768@60.0hz
|
||||||
Audio: Card: Intel 6 Series/C200 Series Family High Definition Audio Controller driver: snd_hda_intel
|
GLX Renderer: Mesa DRI Intel Sandybridge Mobile GLX Version: 3.0 Mesa 10.3.0
|
||||||
Sound: Advanced Linux Sound Architecture ver: k3.13.0-45-generic
|
Audio: Card: Intel 6 Series/C200 Series Family High Definition Audio Controller driver: snd_hda_intel
|
||||||
Network: Card-1: Qualcomm Atheros AR9285 Wireless Network Adapter (PCI-Express) driver: ath9k
|
Sound: Advanced Linux Sound Architecture ver: k3.13.0-45-generic
|
||||||
IF: wlan0 state: up mac:
|
Network: Card-1: Qualcomm Atheros AR9285 Wireless Network Adapter (PCI-Express) driver: ath9k
|
||||||
Card-2: Realtek RTL8101E/RTL8102E PCI Express Fast Ethernet controller driver: r8169
|
IF: wlan0 state: up mac:
|
||||||
IF: eth0 state: down mac:
|
Card-2: Realtek RTL8101E/RTL8102E PCI Express Fast Ethernet controller driver: r8169
|
||||||
Drives: HDD Total Size: 500.1GB (52.5% used) 1: id: /dev/sda model: ST9500325AS size: 500.1GB
|
IF: eth0 state: down mac:
|
||||||
Partition: ID: / size: 455G used: 245G (57%) fs: ext4 ID: /boot size: 236M used: 159M (72%) fs: ext2
|
Drives: HDD Total Size: 500.1GB (52.5% used) 1: id: /dev/sda model: ST9500325AS size: 500.1GB
|
||||||
ID: swap-1 size: 4.19GB used: 0.00GB (0%) fs: swap
|
Partition: ID: / size: 455G used: 245G (57%) fs: ext4 ID: /boot size: 236M used: 159M (72%) fs: ext2
|
||||||
RAID: No RAID devices detected - /proc/mdstat and md_mod kernel raid module present
|
ID: swap-1 size: 4.19GB used: 0.00GB (0%) fs: swap
|
||||||
Sensors: System Temperatures: cpu: 64.5C mobo: N/A
|
RAID: No RAID devices detected - /proc/mdstat and md_mod kernel raid module present
|
||||||
Fan Speeds (in rpm): cpu: N/A
|
Sensors: System Temperatures: cpu: 64.5C mobo: N/A
|
||||||
Info: Processes: 186 Uptime: 6:52 Memory: 1547.2/3861.3MB Client: Shell (bash) inxi: 1.9.17
|
Fan Speeds (in rpm): cpu: N/A
|
||||||
|
Info: Processes: 186 Uptime: 6:52 Memory: 1547.2/3861.3MB Client: Shell (bash) inxi: 1.9.17
|
||||||
As you see in the above, inxi displays the complete hardware details.
|
|
||||||
|
就像上面你看到的那样,inxi显示出了完整的硬件详情信息。
|
||||||
For more details, refer the man pages.
|
|
||||||
|
更多的细节可以参考man手册。
|
||||||
man inxi
|
|
||||||
|
man inxi
|
||||||
### Conclusion ###
|
|
||||||
|
### 结论 ###
|
||||||
Are you searching for a simple tool which displays your complete system and hardware details? Then, don’t look anywhere, inxi will give you what actually want. And, it is light weight tool available in your default repositories. What else you want more? Give it a try, you won’t be disappointed.
|
|
||||||
|
你在寻找一个可以显示完整的系统和硬件详情信息的简单工具吗?那么不用再找了,inxi会提供你所需要的。并且,它还是在你系统默认的软件仓库中的轻量级工具。你还想要更多东西吗?试一试它,你不会失望。
|
||||||
Cheers!
|
|
||||||
|
欢呼吧!
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
via: http://www.unixmen.com/inxi-find-system-hardware-information-linux/
|
|
||||||
|
via: http://www.unixmen.com/inxi-find-system-hardware-information-linux/
|
||||||
作者:[SK][a]
|
|
||||||
译者:[译者ID](https://github.com/译者ID)
|
作者:[SK][a]
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
译者:[goreliu](https://github.com/goreliu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
[a]:http://www.unixmen.com/author/sk/
|
|
||||||
[1]:http://www.unixmen.com/screenfetch-bash-screenshot-information-tool/
|
[a]:http://www.unixmen.com/author/sk/
|
||||||
|
[1]:https://linux.cn/article-1947-1.html
|
@ -0,0 +1,60 @@
|
|||||||
|
zBackup:一个多功能的去重备份工具
|
||||||
|
================================================================================
|
||||||
|
zbackup是一个基于rsync思想的全局去重数据备份工具。给它传入一个大的tar文件后,它会仅存储一次该文件的重复部分,然后对结果进行压缩,并根据参数确定是否对其加密。传入另一个tar文件后,它会从之前的已备份文件中复用重复数据。只有新的改动会被保存,并且只要文件差异不是很大,需要的存储空间非常少。无论何时,之前的已备份文件都可以被完整地读出来。
|
||||||
|
|
||||||
|
### zBackup特性 ###
|
||||||
|
|
||||||
|
- 使用并行的LZMA或者LZO压缩算法压缩已备份数据
|
||||||
|
- 使用内置的AES加密算法加密已备份数据
|
||||||
|
- 可以删除旧的已备份数据
|
||||||
|
- 使用一个64位滚动哈希,保持软碰撞数量为0
|
||||||
|
- 备份库由不可更改的文件组成,只有库中不存在的文件才能修改
|
||||||
|
- 使用C++语言编写,并且只有适量的依赖库
|
||||||
|
- 可以在生产环境安全使用
|
||||||
|
- 可以在不同备份库中交换数据而无需重新压缩
|
||||||
|
|
||||||
|
### 在ubuntu中安装zBackup ###
|
||||||
|
|
||||||
|
打开终端并运行如下命令:
|
||||||
|
|
||||||
|
sudo apt-get install zbackup
|
||||||
|
|
||||||
|
### 使用zBackup ###
|
||||||
|
|
||||||
|
`zbackup init`命令会初始化一个备份库,用来存放待备份的数据。
|
||||||
|
|
||||||
|
zbackup init [--non-encrypted] [--password-file ~/.my_backup_password ] /my/backup/repo
|
||||||
|
|
||||||
|
`zbackup backup`命令备份一个由`tar c`命令创建的tar文件到刚才使用`zbackup init`初始化的备份库。(LCTT 译注:实际使用时类似这样,tar c files | zbackup ...)
|
||||||
|
|
||||||
|
zbackup [--password-file ~/.my_backup_password ] [--threads number_of_threads ] backup /my/backup/repo/backups/backup-`date ‘+%Y-%m-%d'`
|
||||||
|
|
||||||
|
`zbackup restore`命令从备份库中恢复一个已备份文件到tar文件中。
|
||||||
|
|
||||||
|
zbackup [--password-file ~/.my_backup_password ] [--cache-size cache_size_in_mb ] restore /my/backup/repo/backups/backup-`date ‘+%Y-%m-%d'` > /my/precious/backup-restored.tar
|
||||||
|
|
||||||
|
### 可用选项 ###
|
||||||
|
|
||||||
|
- -non-encrypted -- 不加密备份库。
|
||||||
|
- --password-file ~/.my_backup_password -- 使用位于~/.my_backup_password的口令文件来加密备份库和待备份文件,以及解密已备份文件。
|
||||||
|
- --threads number_of_threads -- 限制并行LZMA压缩的线程数为 number_of_threads。建议在32位的系统平台使用。
|
||||||
|
- --cache-size cache_size_in_mb -- 使用cache_size_in_mb中的缓存大小来加速恢复文件的过程。
|
||||||
|
|
||||||
|
### 上述命令中 zBackup 相关文件 ###
|
||||||
|
|
||||||
|
- ~/.my_backup_password 用来加密备份库和待备份文件,以及解密已备份文件。更多细节见zbackup。
|
||||||
|
- /my/backup/repo 存放备份库的目录。
|
||||||
|
- /my/precious/restored-tar 用来恢复已备份文件的tar文件。
|
||||||
|
- /my/backup/repo/backups/backup-`date ‘+%Y-%m-%d'` 指定的之前已备份文件的文件名。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.ubuntugeek.com/zbackup-a-versatile-deduplicating-backup-tool.html
|
||||||
|
|
||||||
|
作者:[ruchi][a]
|
||||||
|
译者:[goreliu](https://github.com/goreliu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.ubuntugeek.com/author/ubuntufix
|
@ -0,0 +1,67 @@
|
|||||||
|
在Ubuntu 14.10上安装基于Web的监控工具:Linux-Dash
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
Linux-Dash是一个用于GNU/Linux机器的,低开销的监控仪表盘。您可以安装试试!Linux Dash的界面提供了您的服务器的所有关键信息的详细视图,可监测的信息包括RAM、磁盘使用率、网络、安装的软件、用户、运行的进程等。所有的信息都被分成几类,您可以通过主页工具栏中的按钮跳到任何一类中。Linux Dash并不是最先进的监测工具,但它十分适合寻找灵活、轻量级、容易部署的应用的用户。
|
||||||
|
|
||||||
|
### Linux-Dash的功能 ###
|
||||||
|
|
||||||
|
- 使用一个基于Web的漂亮的仪表盘界面来监控服务器信息
|
||||||
|
- 实时的按照你的要求监控RAM、负载、运行时间、磁盘配置、用户和许多其他系统状态
|
||||||
|
- 支持基于Apache2/niginx + PHP的服务器
|
||||||
|
- 通过点击和拖动来重排列控件
|
||||||
|
- 支持多种类型的linux服务器
|
||||||
|
|
||||||
|
### 当前控件列表 ###
|
||||||
|
|
||||||
|
- 通用信息
|
||||||
|
- 平均负载
|
||||||
|
- RAM
|
||||||
|
- 磁盘使用量
|
||||||
|
- 用户
|
||||||
|
- 软件
|
||||||
|
- IP
|
||||||
|
- 网络速率
|
||||||
|
- 在线状态
|
||||||
|
- 处理器
|
||||||
|
- 日志
|
||||||
|
|
||||||
|
### 在Ubuntu server 14.10上安装Linux-Dash ###
|
||||||
|
|
||||||
|
首先您需要确认您安装了[Ubuntu LAMP server 14.10][1],接下来您需要安装下面的包:
|
||||||
|
|
||||||
|
sudo apt-get install php5-json unzip
|
||||||
|
|
||||||
|
安装这个模块后,需要在apache2中启用该模块,所以您需要使用下面的命令重启apache2服务器:
|
||||||
|
|
||||||
|
sudo service apache2 restart
|
||||||
|
|
||||||
|
现在您需要下载linux-dash的安装包并安装它:
|
||||||
|
|
||||||
|
wget https://github.com/afaqurk/linux-dash/archive/master.zip
|
||||||
|
|
||||||
|
unzip master.zip
|
||||||
|
|
||||||
|
sudo mv linux-dash-master/ /var/www/html/linux-dash-master/
|
||||||
|
|
||||||
|
接下来您需要使用下面的命令来改变权限:
|
||||||
|
|
||||||
|
sudo chmod 755 /var/www/html/linux-dash-master/
|
||||||
|
|
||||||
|
现在您便可以访问http://serverip/linux-dash-master/了。您应该会看到类似下面的输出:
|
||||||
|
|
||||||
|
![](http://www.ubuntugeek.com/wp-content/uploads/2015/02/1.png)
|
||||||
|
|
||||||
|
![](http://www.ubuntugeek.com/wp-content/uploads/2015/02/2.png)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.ubuntugeek.com/install-linux-dash-web-based-monitoring-tool-on-ubntu-14-10.html
|
||||||
|
|
||||||
|
作者:[ruchi][a]
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.ubuntugeek.com/author/ubuntufix
|
||||||
|
[1]:http://www.ubuntugeek.com/step-by-step-ubuntu-14-10-utopic-unicorn-lamp-server-setup.html
|
@ -0,0 +1,115 @@
|
|||||||
|
使用 ARChon 运行时环境在 Ubuntu 上运行 Android 应用
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
在此之前,我们尝试过在多款安卓应用模拟器工具上运行安卓应用,比如Genymotion、VirtualBox和Android SDK等。但是,有了这套全新的Chrome安卓运行环境,就可以在Chrome浏览器中运行安卓应用了。所以,下面是一些步骤来指导你如何使用ARChon运行时环境在Ubuntu上安装安卓应用。
|
||||||
|
|
||||||
|
谷歌已经公布了[首批支持原生运行在Chrome OS的安卓应用][1],而这个全新的“**安卓运行时环境**”扩展程序使其成为可能。如今,一位名为Vlad Filippov的开发者已经找到了一种把安卓应用移植到桌面端Chrome浏览器的方法。他把chromeos-apk脚本和ARChon安卓运行环境扩展程序两者紧密结合在一起,使得安卓应用可以运行在Windows、Max和Linux系统的桌面端Chrome浏览器中。
|
||||||
|
|
||||||
|
应用借助这种运行环境时的性能并不是很好。同样,由于它是官方运行环境的非官方二次开发包,而且运行在Google的Chrome OS之外,因此一些如摄像头和喇叭等系统内置设备可能需要通过打补丁获得或者根本不支持。
|
||||||
|
|
||||||
|
### 安装Chrome ###
|
||||||
|
|
||||||
|
首先,需要在机器上安装Chrome,版本要求是Chrome 37或者更高。可以从[Chrome浏览器的下载页面][2]下载。
|
||||||
|
|
||||||
|
如果打算安装开发通道版本,按照如下操作。
|
||||||
|
|
||||||
|
使用这个命令为Google Chrome添加软件源列表:
|
||||||
|
|
||||||
|
$ wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | sudo apt-key add -
|
||||||
|
$ sudo sh -c 'echo "deb http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list'
|
||||||
|
|
||||||
|
![Adding google source list](http://blog.linoxide.com/wp-content/uploads/2015/02/adding-google-source-list.png)
|
||||||
|
|
||||||
|
添加完软件源列表后,使用下列命令更新本地的软件库索引。
|
||||||
|
|
||||||
|
$ sudo apt-get update
|
||||||
|
|
||||||
|
现在,就可以安装非稳定版的google chrome,即开发版:
|
||||||
|
|
||||||
|
$ sudo apt-get install google-chrome-unstable
|
||||||
|
|
||||||
|
![Installing Google chrome unstable](http://blog.linoxide.com/wp-content/uploads/2015/02/installing-google-chrome-unstable.png)
|
||||||
|
|
||||||
|
### 安装Archon运行时环境 ###
|
||||||
|
|
||||||
|
接下来,需要下载定制版的运行环境安装包,因为官方版本不被Google或Vlad Filippov创建的Chromium安卓运行环境认可。它在很多方面有别于官方版本,主要区别是它可以用于Google浏览器的各个桌面端。下面是需要下载的运行环境安装包,请根据所安装的Ubuntu系统位数选择下列的一种。
|
||||||
|
|
||||||
|
**32位** Ubntu发行版:
|
||||||
|
|
||||||
|
- [下载 32 位版 Ubuntu 上的 Archron][3]
|
||||||
|
|
||||||
|
**64位** Ubntu发行版:
|
||||||
|
|
||||||
|
- [下载 64 位版 Ubuntu 上的 Archron][4]
|
||||||
|
|
||||||
|
下载好运行环境安装包后,从.zip文件中解压,并将解压得到的目录移动到Home目录。操作命令如下:
|
||||||
|
|
||||||
|
$ wget https://github.com/vladikoff/chromeos-apk/releases/download/v3.0.0/ARChon-v1.1-x86_32.zip
|
||||||
|
|
||||||
|
![Downloading ARChon](http://blog.linoxide.com/wp-content/uploads/2015/02/download-archon.png)
|
||||||
|
|
||||||
|
$ unzip ARChon-v1.1-x86_32.zip ~/
|
||||||
|
|
||||||
|
接下来是安装运行时环境,首先打开Google Chrome浏览器,在地址栏键入**chrome://extensions**。然后,选中“**开发者模式**”。最后,点击“**载入未打包扩展程序**”,选择刚才放置在**~/Home**下面的文件夹。
|
||||||
|
|
||||||
|
### 安装 ChromeOS-APK ###
|
||||||
|
|
||||||
|
如果要用到上面提到的那些应用,那么手动转换这些APK无需复杂的操作——只需要安装“[chromeos-apk][5]”命令行JavaScript工具。可以在Node Package Modules(npm)管理器中安装它。为了安装npm和chromeos-apk,在shell或终端中运行下面命令:
|
||||||
|
|
||||||
|
$ sudo apt-get install npm nodejs nodejs-legacy
|
||||||
|
|
||||||
|
如果**操作系统是64位**,需要安装下面这个库,命令如下:
|
||||||
|
|
||||||
|
$ sudo apt-get install lib32stdc++6
|
||||||
|
|
||||||
|
然后,运行这条命令来安装最新的chromeos-apk:
|
||||||
|
|
||||||
|
$ npm install -g chromeos-apk@latest
|
||||||
|
|
||||||
|
![chromeos apk installation](http://blog.linoxide.com/wp-content/uploads/2015/02/chomeos-apk-installation.png)
|
||||||
|
|
||||||
|
取决于系统配置,可能需要以sudo权限运行后一条命令。
|
||||||
|
|
||||||
|
现在,我们将找一个应用程序的APK来在Google浏览器上试一试,但务必牢记**并非所有的安卓应用都可以**,有一些可能不稳定或者缺少某些特性。大部分安装即用的通讯类应用都不适用这个环境。
|
||||||
|
|
||||||
|
### 转换APK ###
|
||||||
|
|
||||||
|
将**安卓APK放到~/Home**下,然后在**终端**执行下列命令进行转换:
|
||||||
|
|
||||||
|
$ chromeos-apk myapp.apk --archon
|
||||||
|
|
||||||
|
如果想以全屏模式运行应用,请替换成这条命令:
|
||||||
|
|
||||||
|
$ chromeos-apk myapp.apk --archon --tablet
|
||||||
|
|
||||||
|
注意:请将myapp.apk替换成待转换的安卓APK应用的文件名。
|
||||||
|
|
||||||
|
为了方便,也可以使用[Twerk][6]来进行转换,这样可以跳过这一步。
|
||||||
|
|
||||||
|
### 运行安卓Apk ###
|
||||||
|
|
||||||
|
最后,打开chrome浏览器,然后进入chrome://extensions页面,勾选开发者模式。点击“载入未打包扩展程序”按钮,选择上面脚本刚创建的文件夹。
|
||||||
|
|
||||||
|
至此,就可以打开Chrome应用启动器运行安卓应用了。
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
万岁!我们已经成功在Chrome浏览器中安装好安卓Apk应用程序了。这篇文章是关于一款由Vlad Filippov开发的、名为Archon的、时下流行的Chrome安卓运行环境。这个运行环境使用户在Chrome浏览器中运行转换过的Apk文件。目前它还不支持通讯类应用,诸如Whatsapp。因此,如果你有任何问题、建议和反馈,请在下面的评论框中写出来。非常感谢!去拥抱Archon吧!:-)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://linoxide.com/ubuntu-how-to/android-apps-ubuntu-archon-runtime/
|
||||||
|
|
||||||
|
作者:[Arun Pyasi][a]
|
||||||
|
译者:[KayGuoWhu](https://github.com/KayGuoWhu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://linoxide.com/author/arunp/
|
||||||
|
[1]:http://chrome.blogspot.com/2014/09/first-set-of-android-apps-coming-to.html
|
||||||
|
[2]:https://www.google.com/chrome/browser
|
||||||
|
[3]:https://github.com/vladikoff/chromeos-apk/releases/download/v3.0.0/ARChon-v1.1-x86_32.zip
|
||||||
|
[4]:https://github.com/vladikoff/chromeos-apk/releases/download/v3.0.0/ARChon-v1.1-x86_64.zip
|
||||||
|
[5]:https://github.com/vladikoff/chromeos-apk/blob/master/README.md
|
||||||
|
[6]:https://chrome.google.com/webstore/detail/twerk/jhdnjmjhmfihbfjdgmnappnoaehnhiaf
|
@ -0,0 +1,300 @@
|
|||||||
|
指南:使用Trickle限制应用程序带宽占用
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
有没有遇到过系统中的某个应用程序独占了你所有的网络带宽的情形?如果你有过这样的遭遇,那么你就会感受到Trickle这种带宽调整应用的价值。不管你是一个系统管理员还只是普通Linux用户,都需要学习如何控制应用程序的上下行速度,来确保你的网络带宽不会被某个程序霸占。
|
||||||
|
|
||||||
|
![Install Trickle Bandwidth Limit in Linux](http://www.tecmint.com/wp-content/uploads/2013/11/Bandwidth-limit-trickle.png)
|
||||||
|
|
||||||
|
*在 Linux 上安装 Trickle 带宽限制*
|
||||||
|
|
||||||
|
### 什么是 Trickle? ###
|
||||||
|
|
||||||
|
Trickle是一个网络带宽调整工具,可以让我们管理应用程序的网络上下行速度,使得可以避免其中的某个应用程序霸占了全部或大部分可用的带宽。换句话说,Trickle可以让你基于单个应用程序来控制网络流量速率,而不是仅仅针对与单个用户——这是在客户端网络环境中经典的带宽调整情况。
|
||||||
|
|
||||||
|
### Trickle 是如何工作的?###
|
||||||
|
|
||||||
|
另外,trickle 可以帮助我们基于应用来定义优先级,所以当对整个系统进行了全局限制设定,高优先级的应用依然会自动地获取更多的带宽。为了实现这个目标,trickle 对 TCP 连接上的套接字的数据发送、接收设置流量限制。我们必须注意到,除了影响传输速率之外,在这个过程中,trickle任何时候都不会以任何方式来改变其中的数据。
|
||||||
|
|
||||||
|
### Trickle不能做什么? ###
|
||||||
|
|
||||||
|
这么说吧,唯一的限制就是,trickle不支持静态链接的应用程序或者具有SUID或SGID位设置的二进制程序,因为它使用动态链接的方式将其载入到需要调整的进程和其关联的网络套接字之间。 Trickle此时会在这两种软件组件之间扮演代理的角色。
|
||||||
|
|
||||||
|
由于trickle并不需要超级用户的权限来运行,所以用户可以设置他们自己的流量限制。可能这并不是你想要的,我们会探索如何使用全局设定来限制系统中的所有用户的流量限制。也即是说,此时系统中的每个用户具有管理各自的流量速率,但是无论如何,都会受到系统管理员给他们设置的总体限制。
|
||||||
|
|
||||||
|
在这篇文章中,我们会描述如何通过trickle在linux平台上管理应用程序使用的网络带宽。为了生成所需的流量,在此会在客户端(CentOS 7 server – dev1: 192.168.0.17)上使用 ncftpput 和 ncftpget, 在服务器(Debian Wheezy 7.5 – dev2: 192.168.0.15)上使用vsftpd 来进行演示。 相同的指令也可以在RedHat,Fedora和Ubuntu等系统使用。
|
||||||
|
|
||||||
|
#### 前提条件 ####
|
||||||
|
|
||||||
|
1. 对于 RHEL/CentOS 7/6, [开启EPEL仓库][1]。这些用于企业版 Linux 的额外软件包是一个由Fedora项目维护的高质量、开源的软件仓库,而且百分之百与其衍生产品相兼容,如企业版本Linux和CentOS。 在这个仓库中trickle和ncftp两者都是可用的。
|
||||||
|
|
||||||
|
2. 按照如下方式安装ncftp:
|
||||||
|
|
||||||
|
# yum update && sudo yum install ncftp [基于 RedHat 的系统]
|
||||||
|
# aptitude update && aptitude install ncftp [基于 Debian 的系统]
|
||||||
|
|
||||||
|
3. 在单独的服务器上设置一个FTP服务器。需要注意的是,尽管FTP天生就不安全,但是仍然被广泛应用在安全性无关紧要的文件上传下载中。 在这篇文章中我们使用它来演示trickle的优点,同时它也会在客户端的标准输出流中显示传输速率。我们将是否在其它时间使用它放在一边讨论。
|
||||||
|
|
||||||
|
# yum update && yum install vsftpd [基于 RedHat 的系统]
|
||||||
|
# aptitude update && aptitude install vsftpd [基于 Debian 的系统]
|
||||||
|
|
||||||
|
现在,在FTP服务器上按照以下方式编辑 /etc/vsftpd/vsftpd.conf 文件。
|
||||||
|
|
||||||
|
anonymous_enable=NO
|
||||||
|
local_enable=YES
|
||||||
|
chroot_local_user=YES
|
||||||
|
allow_writeable_chroot=YES
|
||||||
|
|
||||||
|
在此之后,确保在你的当前会话中启动了vsftpd,并在之后的启动中让其自动启动。
|
||||||
|
|
||||||
|
# systemctl start vsftpd [基于 systemd 的系统]
|
||||||
|
# systemctl enable vsftpd
|
||||||
|
# service vsftpd start [基于 init 的系统]
|
||||||
|
# chkconfig vsftpd on
|
||||||
|
|
||||||
|
4. 如果你选择在一个使用 SSH 密钥进行远程访问的 CentOS/RHEL 7中搭建FTP服务器,你需要一个密码受保护的用户账户,它能访问**root目录之外**的某个目录,并有能在其中上传和下载文件的权限。
|
||||||
|
|
||||||
|
你可以通过在你的浏览器中输入以下的URL来浏览你的家目录。一个登录窗口会弹出来提示你输入FTP服务器中的有效的用户名和密码。
|
||||||
|
|
||||||
|
ftp://192.168.0.15
|
||||||
|
|
||||||
|
如果验证成功,你就会看到你的家目录中的内容。该教程的稍后部分中,你将可以刷新页面来显示在你之前上传过的文件。
|
||||||
|
|
||||||
|
![FTP Directory Tree](http://www.tecmint.com/wp-content/uploads/2013/11/FTP-Directory-Tree.png)
|
||||||
|
|
||||||
|
*FTP 目录树*
|
||||||
|
|
||||||
|
### 如何在Linux中安装 trickle ###
|
||||||
|
|
||||||
|
1. 通过yum或aptitude来安装trickle.
|
||||||
|
|
||||||
|
为了确保能够成功安装,最好在安装工具之前,保证当前的安装包是最新的版本。
|
||||||
|
|
||||||
|
|
||||||
|
# yum -y update && yum install trickle [基于 RedHat 的系统]
|
||||||
|
# aptitude -y update && aptitude install trickle [基于 Debian 的系统]
|
||||||
|
|
||||||
|
2. 确认trickle是否对特定的二进制包有用。
|
||||||
|
|
||||||
|
之前我们解释过,trickle只对使用动态或共享的库的二进制包有用。为了确认我们是否可以对某个特定的应用使用trickle,我们可以使用著名的ldd(列出动态依赖)工具。 特别地,我们会查看任何给定程序的动态依赖中其当前使用的glibc,因为其准确地定义了通过套接字通讯所使用的系统调用。
|
||||||
|
|
||||||
|
对一个给定的二进制包执行以下命令来查看是否能对其使用trickle进行带宽调整:
|
||||||
|
|
||||||
|
# ldd $(which [binary]) | grep libc.so
|
||||||
|
|
||||||
|
例如,
|
||||||
|
|
||||||
|
# ldd $(which ncftp) | grep libc.so
|
||||||
|
|
||||||
|
其输出是:
|
||||||
|
|
||||||
|
# libc.so.6 => /lib64/libc.so.6 (0x00007efff2e6c000)
|
||||||
|
|
||||||
|
输出中的括号中的字符可能在不同的系统平台有所不同,甚至相同的命令在不同的时候运行也会不同,因为其代表包加载到物理内存中的地址。
|
||||||
|
|
||||||
|
如果上面的命令没有返回任何的结果,就说明这个二进制包没有使用libc包,因此trickle对其不能起到带宽调整的作用。
|
||||||
|
|
||||||
|
### 学习如何使用Trickle###
|
||||||
|
|
||||||
|
最基本的用法就是使用其独立模式,通过这种方式,trickle用来显式地定义给定应用程序的上传下载速率。如前所述,为了简单,我们会使用相同的应用来进行上传下载测试。
|
||||||
|
|
||||||
|
#### 在独立模式下运行trickle####
|
||||||
|
|
||||||
|
我们会比较在有无trickle的情况下的上传下载速率, ‘-d’选项指示下载速率(KB/s单位),而'-u'选项指示相同单位的上传速率。另外我们会使用到‘-s’选项来指定trickle应该以独立模式运行。
|
||||||
|
|
||||||
|
以独立模式运行trickle的基本语法如下:
|
||||||
|
|
||||||
|
# trickle -s -d [下载速率,KB/s] -u [上传速率,KB/s]
|
||||||
|
|
||||||
|
为了能够让你自己运行以下样例,确保你在自己的客户端安装了trickle和ncftp(我的是192.168.0.17)。
|
||||||
|
|
||||||
|
**样例1:在有无trickle的情况下上传一个2.8 MB的PDF文件。**
|
||||||
|
|
||||||
|
我们使用一个自由发布的[LInux基础知识PDF文件][2]来进行下面的测试。
|
||||||
|
|
||||||
|
你可以首先使用下面的命令将这个文件下载到你当前的工作目录中:
|
||||||
|
|
||||||
|
# wget http://linux-training.be/files/books/LinuxFun.pdf
|
||||||
|
|
||||||
|
下面是在没有trickle的情况下将一个文件上传到我们的FTP服务器的语法:
|
||||||
|
|
||||||
|
# ncftpput -u username -p password 192.168.0.15 /remote_directory local-filename
|
||||||
|
|
||||||
|
其中的 /remote_directory 是相对于该用户的家目录的上传路径,而local-filename是一个你当前工作目录中的文件。
|
||||||
|
|
||||||
|
特别的是,在没有trickle的情形下,我们可以得到上传峰值速率52.02MB/s(请注意,这个不是真正的平均上传速率,而是峰值开始的瞬时值),而且这个文件几乎在瞬间就完成了上传。
|
||||||
|
|
||||||
|
# ncftpput -u username -p password 192.168.0.15 /testdir LinuxFun.pdf
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
LinuxFun.pdf: 2.79 MB 52.02 MB/s
|
||||||
|
|
||||||
|
在使用trickle的情况下,我们会限制上传速率在5KB/s。在第二次上传文件之前,我们需要在目标目录中删除这个文件,否则ncftp就会通知我们在目标目录中已经存在了与上传文件相同的文件,从而不会执行文件的传输:
|
||||||
|
|
||||||
|
# rm /absolute/path/to/destination/directory/LinuxFun.pdf
|
||||||
|
|
||||||
|
然后:
|
||||||
|
|
||||||
|
# trickle -s -u 5 ncftpput -u username -p password 111.111.111.111 /testdir LinuxFun.pdf
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
LinuxFun.pdf: 2.79 MB 4.94 kB/s
|
||||||
|
|
||||||
|
在上面的样例中,我们看到平均的上传速率下降到了5KB/s。
|
||||||
|
|
||||||
|
**样例2:在有无trickle的情况下下载相同的2.8MB的PDF文件**
|
||||||
|
|
||||||
|
首先,记得从原来的源目录中删除这个PDF:
|
||||||
|
|
||||||
|
# rm /absolute/path/to/source/directory/LinuxFun.pdf
|
||||||
|
|
||||||
|
请注意,下面的样例中将远程的文件下载到客户端机器的当前目录下,这是由FTP服务器的IP地址后面的“.”决定的。
|
||||||
|
|
||||||
|
没有trickle的情况下:
|
||||||
|
|
||||||
|
# ncftpget -u username -p password 111.111.111.111 . /testdir/LinuxFun.pdf
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
LinuxFun.pdf: 2.79 MB 260.53 MB/s
|
||||||
|
|
||||||
|
在有trickle的情况下,限制下载速率在20KB/s:
|
||||||
|
|
||||||
|
# trickle -s -d 30 ncftpget -u username -p password 111.111.111.111 . /testdir/LinuxFun.pdf
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
LinuxFun.pdf: 2.79 MB 17.76 kB/s
|
||||||
|
|
||||||
|
### 在监督[非托管]模式下运行Trickle ###
|
||||||
|
|
||||||
|
trickle也可以按照/etc/trickled.conf文件中定义的一系列参数运行在非托管模式下。 这个文件定义了守护线程 trickled的行为以及如何管理trickle。
|
||||||
|
|
||||||
|
另外,如果你想要全局设置被所有的应用程序使用的话,我们就会需要使用trickle命令。 这个命令运行守护进程,并允许我们通过trickle定义所有应用程序共享的上传下载限制,不需要我们每次来进行指定。
|
||||||
|
|
||||||
|
例如,运行:
|
||||||
|
|
||||||
|
# trickled -d 50 -u 10
|
||||||
|
|
||||||
|
会导致任何通过trickle运行的应用程序的上传下载速率分别限制在30kb/s和10kb/s。
|
||||||
|
|
||||||
|
请注意,你可以在任何时间都能确认守护线程trickled是否正在运行以及其运行参数:
|
||||||
|
|
||||||
|
# ps -ef | grep trickled | grep -v grep
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
root 16475 1 0 Dec24 ? 00:00:04 trickled -d 50 -u 10
|
||||||
|
|
||||||
|
**样例3:在使用/不使用trickle的情形下上传一个 19MB 的mp4文件到我们的FTP服务器。**
|
||||||
|
|
||||||
|
在这个样例中,我们会使用“He is the gift”的自由分发视频,可以通过这个[链接][3]下载。
|
||||||
|
|
||||||
|
我们将会在开始时通过以下的命令将这个文件下载到你的当前工作目录中:
|
||||||
|
|
||||||
|
# wget http://media2.ldscdn.org/assets/missionary/our-people-2014/2014-00-1460-he-is-the-gift-360p-eng.mp4
|
||||||
|
|
||||||
|
首先,我们会使用之前列出的命令来开启守护进程trickled:
|
||||||
|
|
||||||
|
# trickled -d 30 -u 10
|
||||||
|
|
||||||
|
在不使用trickle时:
|
||||||
|
|
||||||
|
# ncftpput -u username -p password 192.168.0.15 /testdir 2014-00-1460-he-is-the-gift-360p-eng.mp4
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
2014-00-1460-he-is-the-gift-360p-eng.mp4: 18.53 MB 36.31 MB/s
|
||||||
|
|
||||||
|
在使用trickle时:
|
||||||
|
|
||||||
|
# trickle ncftpput -u username -p password 192.168.0.15 /testdir 2014-00-1460-he-is-the-gift-360p-eng.mp4
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
2014-00-1460-he-is-the-gift-360p-eng.mp4: 18.53 MB 9.51 kB/s
|
||||||
|
|
||||||
|
我们可以看到上面的输出,上传的速率下降到了约 10KB/s。
|
||||||
|
|
||||||
|
** 样例4:在使用/不使用trickle的情形下下载这个相同的视频 **
|
||||||
|
|
||||||
|
与样例2一样,我们会将该文件下载到当前工作目录中。
|
||||||
|
|
||||||
|
在没有trickle时:
|
||||||
|
|
||||||
|
# ncftpget -u username -p password 192.168.0.15 . /testdir/2014-00-1460-he-is-the-gift-360p-eng.mp4
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
2014-00-1460-he-is-the-gift-360p-eng.mp4: 18.53 MB 108.34 MB/s
|
||||||
|
|
||||||
|
有trickle的时:
|
||||||
|
|
||||||
|
# trickle ncftpget -u username -p password 111.111.111.111 . /testdir/2014-00-1460-he-is-the-gift-360p-eng.mp4
|
||||||
|
|
||||||
|
输出:
|
||||||
|
|
||||||
|
2014-00-1460-he-is-the-gift-360p-eng.mp4: 18.53 MB 29.28 kB/s
|
||||||
|
|
||||||
|
上面的结果与我们之前设置的下载限速相对应(30KB/s)。
|
||||||
|
|
||||||
|
**注意:** 一旦守护进程开启之后,就没有必要使用trickle来为每个应用程序来单独设置限制。
|
||||||
|
|
||||||
|
如前所述,人们可以进一步地通过trickled.conf来客制化trickle的带宽速率调整,该文件的一个典型的分段有以下部分组成:
|
||||||
|
|
||||||
|
[service]
|
||||||
|
Priority = <value>
|
||||||
|
Time-Smoothing = <value>
|
||||||
|
Length-Smoothing = <value>
|
||||||
|
|
||||||
|
其中,
|
||||||
|
|
||||||
|
- [service] 用来指示我们想要对其进行带宽使用调整的应用程序名称
|
||||||
|
- Priority 用来让我们为某个服务制定一个相对于其他服务高的优先级,这样就不允许守护进程管理中的一个单独的应用程序来占用所有的带宽。越小的数字代表更高的优先级。
|
||||||
|
- Time-Smoothing [以秒计]: 定义了trickled让各个应用程序传输或接收数据的时间间隔。小的间隔值(0.1-1秒)对于交互式应用程序是理想的,因为这样会具有一个更加平滑的会话体验,而一个相对较大的时间间隔值(1-10秒)对于需要批量传输应用程序就会显得更好。如果没有指定该值,默认是5秒。
|
||||||
|
- Length-smoothing [KB 单位]: 该想法与Time-Smoothing如出一辙,但是是基于I/O操作而言。如果没有指定值,会使用默认的10KB。
|
||||||
|
|
||||||
|
上述平滑值(Time-Smoothing、 Length-smoothing)的改变会被翻译为将指定的服务的使用一个间隔值而不是一个固定值。不幸的是,没有一个特定的公式来计算间隔值的上下限,主要依赖于特定的应用场景。
|
||||||
|
|
||||||
|
下面是一个在CentOS 7 客户端中的trickled.conf 样例文件(192.168.0.17):
|
||||||
|
|
||||||
|
[ssh]
|
||||||
|
Priority = 1
|
||||||
|
Time-Smoothing = 0.1
|
||||||
|
Length-Smoothing = 2
|
||||||
|
|
||||||
|
[ftp]
|
||||||
|
Priority = 2
|
||||||
|
Time-Smoothing = 1
|
||||||
|
Length-Smoothing = 3
|
||||||
|
|
||||||
|
使用该设置,trickled会为SSH赋予比FTP较高的传输优先级。值得注意的是,一个交互进程,例如SSH,使用了一个较小的时间间隔值,然而一个处理批量数据传输的服务如FTP,则使用一个较大的时间间隔来控制之前的样例中的上传下载速率,尽管不是百分百的由trickled指定的值,但是也已经非常接近了。
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
在该文章中,我们探索了使用trickle在基于Fedora发行版和Debian衍生版平台上来限制应用程序的带宽使用。也包含了其他的可能用法,但是不对以下情形进行限制:
|
||||||
|
|
||||||
|
- 限制系统工具的下载速度,例如[wget][4],或 BT客户端.
|
||||||
|
- 限制你的系统的包管理工具[`yum`][5]更新的速度 (如果是基于Debian系统的话,其包管理工具为[`aptitude`][6])。
|
||||||
|
- 如果你的服务器是在一个代理或防火墙后面(或者其本身即是代理或防火墙的话),你可以使用trickle来同时设定下载和上传速率,或者客户端或外部通讯的速率。
|
||||||
|
|
||||||
|
欢迎提问或留言。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.tecmint.com/manage-and-limit-downloadupload-bandwidth-with-trickle-in-linux/
|
||||||
|
|
||||||
|
作者:[Gabriel Cánepa][a]
|
||||||
|
译者:[theo-l](https://github.com/theo-l)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.tecmint.com/author/gacanepa/
|
||||||
|
[1]:https://linux.cn/article-2324-1.html
|
||||||
|
[2]:http://linux-training.be/files/books/LinuxFun.pdf
|
||||||
|
[3]:http://media2.ldscdn.org/assets/missionary/our-people-2014/2014-00-1460-he-is-the-gift-360p-eng.mp4
|
||||||
|
[4]:http://www.tecmint.com/10-wget-command-examples-in-linux/
|
||||||
|
[5]:http://www.tecmint.com/20-linux-yum-yellowdog-updater-modified-commands-for-package-mangement/
|
||||||
|
[6]:http://www.tecmint.com/dpkg-command-examples/
|
@ -0,0 +1,174 @@
|
|||||||
|
使用Observium来监控你的网络和服务器
|
||||||
|
================================================================================
|
||||||
|
### 简介###
|
||||||
|
|
||||||
|
在监控你的服务器、交换机或者设备时遇到过问题吗?**Observium** 可以满足你的需求。这是一个免费的监控系统,它可以帮助你远程监控你的服务器。它是一个由PHP编写的基于自动发现 SNMP 的网络监控平台,支持非常广泛的网络硬件和操作系统,包括 Cisco、Windows、Linux、HP、NetApp 等等。在此我会给出在 Ubuntu 12.04 上一步步地设置一个 **Observium** 服务器的介绍。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/Capture1.png)
|
||||||
|
|
||||||
|
目前有两种不同的 **observium** 版本。
|
||||||
|
|
||||||
|
- Observium 社区版本是一个在 QPL 开源许可证下的免费工具,这个版本是对于较小部署的最好解决方案。该版本每6个月进行一次安全性更新。
|
||||||
|
- 第2个版本是 Observium 专业版,该版本采用基于 SVN 的发布机制。 会得到每日安全性更新。 该工具适用于服务提供商和企业级部署。
|
||||||
|
|
||||||
|
更多信息可以通过其[官网][1]获得。
|
||||||
|
|
||||||
|
### 系统需求###
|
||||||
|
|
||||||
|
要安装 **Observium**, 需要具有一个最新安装的服务器。**Observium** 是在 Ubuntu LTS 和 Debian 系统上进行开发的,所以推荐在 Ubuntu 或 Debian 上安装 **Observium**,因为可能在别的平台上会有一些小问题。
|
||||||
|
|
||||||
|
该文章会引导你在 Ubuntu 12.04 上安装 **Observium**。对于小型的 **Observium** 安装,建议使用 256MB 内存和双核处理器的配置。
|
||||||
|
|
||||||
|
### 安装需求 ###
|
||||||
|
|
||||||
|
在安装 **Observuim** 之前,你需要确认安装所有的依赖关系包。
|
||||||
|
|
||||||
|
首先,使用下面的命令更新你的服务器:
|
||||||
|
|
||||||
|
sudo apt-get update
|
||||||
|
|
||||||
|
然后你需要安装下列运行 Observuim 所需的全部软件包。
|
||||||
|
|
||||||
|
Observium 需要使用下面所列出的软件才能正确的运行:
|
||||||
|
|
||||||
|
- LAMP 服务器
|
||||||
|
- fping
|
||||||
|
- Net-SNMP 5.4+
|
||||||
|
- RRDtool 1.3+
|
||||||
|
- Graphviz
|
||||||
|
|
||||||
|
对于可选特性的要求:
|
||||||
|
|
||||||
|
- Ipmitool - 仅在当你想要获取服务器上的 IPMI(Intelligent Platform Management Interface 智能平台管理接口)基板控制器时。
|
||||||
|
- Libvirt-bin - 仅在当你想要使用 libvirt 进行远程 VM 主机监控时。
|
||||||
|
|
||||||
|
sudo apt-get install libapache2-mod-php5 php5-cli php5-mysql php5-gd php5-mcrypt php5-json php-pear snmp fping mysql-server mysql-client python-mysqldb rrdtool subversion whois mtr-tiny ipmitool graphviz imagemagick libvirt ipmitool
|
||||||
|
|
||||||
|
### 为 Observium 创建 MySQL 数据库及其用户。
|
||||||
|
|
||||||
|
现在你需要登录到 MySQL 中并为 **Observium** 创建数据库:
|
||||||
|
|
||||||
|
mysql -u root -p
|
||||||
|
|
||||||
|
在用户验证成功之后,你需要按照下面的命令创建该数据库。
|
||||||
|
|
||||||
|
CREATE DATABASE observium;
|
||||||
|
|
||||||
|
数据库名为 **Observium**,稍后你会需要这个信息。
|
||||||
|
|
||||||
|
现在你需要创建数据库管理员用户。
|
||||||
|
|
||||||
|
CREATE USER observiumadmin@localhost IDENTIFIED BY 'observiumpassword';
|
||||||
|
|
||||||
|
接下来,你需要给该管理员用户相应的权限来管理创建的数据库。
|
||||||
|
|
||||||
|
GRANT ALL PRIVILEGES ON observium.* TO observiumadmin@localhost;
|
||||||
|
|
||||||
|
你需要将权限信息写回到磁盘中来激活新的 MySQL 用户:
|
||||||
|
|
||||||
|
FLUSH PRIVILEGES;
|
||||||
|
exit
|
||||||
|
|
||||||
|
### 下载并安装 Observium###
|
||||||
|
|
||||||
|
现在我们的系统已经准备好了, 可以开始Observium的安装了。
|
||||||
|
|
||||||
|
第一步,创建 Observium 将要使用的文件目录:
|
||||||
|
|
||||||
|
mkdir -p /opt/observium && cd /opt
|
||||||
|
|
||||||
|
按本教程的目的,我们将会使用 Observium 的社区/开源版本。使用下面的命令下载并解压:
|
||||||
|
|
||||||
|
wget http://www.observium.org/observium-community-latest.tar.gz
|
||||||
|
tar zxvf observium-community-latest.tar.gz
|
||||||
|
|
||||||
|
现在进入到 Observium 目录。
|
||||||
|
|
||||||
|
cd observium
|
||||||
|
|
||||||
|
将默认的配置文件 '**config.php.default**' 复制到 '**config.php**',并将数据库配置选项填充到配置文件中:
|
||||||
|
|
||||||
|
cp config.php.default config.php
|
||||||
|
nano config.php
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
/ Database config
|
||||||
|
$config['db_host'] = 'localhost';
|
||||||
|
$config['db_user'] = 'observiumadmin';
|
||||||
|
$config['db_pass'] = 'observiumpassword';
|
||||||
|
$config['db_name'] = 'observium';
|
||||||
|
|
||||||
|
现在为 MySQL 数据库设置默认的数据库模式:
|
||||||
|
|
||||||
|
php includes/update/update.php
|
||||||
|
|
||||||
|
现在你需要创建一个文件目录来存储 rrd 文件,并修改其权限以便让 apache 能将写入到文件中。
|
||||||
|
|
||||||
|
mkdir rrd
|
||||||
|
chown apache:apache rrd
|
||||||
|
|
||||||
|
为了在出现问题时排错,你需要创建日志文件。
|
||||||
|
|
||||||
|
mkdir -p /var/log/observium
|
||||||
|
chown apache:apache /var/log/observium
|
||||||
|
|
||||||
|
现在你需要为 Observium 创建虚拟主机配置。
|
||||||
|
|
||||||
|
<VirtualHost *:80>
|
||||||
|
DocumentRoot /opt/observium/html/
|
||||||
|
ServerName observium.domain.com
|
||||||
|
CustomLog /var/log/observium/access_log combined
|
||||||
|
ErrorLog /var/log/observium/error_log
|
||||||
|
<Directory "/opt/observium/html/">
|
||||||
|
AllowOverride All
|
||||||
|
Options FollowSymLinks MultiViews
|
||||||
|
</Directory>
|
||||||
|
</VirtualHost>
|
||||||
|
|
||||||
|
下一步你需要让你的 Apache 服务器的 rewrite (重写)功能生效。
|
||||||
|
|
||||||
|
为了让 'mod_rewrite' 生效,输入以下命令:
|
||||||
|
|
||||||
|
sudo a2enmod rewrite
|
||||||
|
|
||||||
|
该模块在下一次 Apache 服务重启之后就会生效。
|
||||||
|
|
||||||
|
sudo service apache2 restart
|
||||||
|
|
||||||
|
###配置 Observium###
|
||||||
|
|
||||||
|
在登入 Web 界面之前,你需要为 Observium 创建一个管理员账户(级别10)。
|
||||||
|
|
||||||
|
# cd /opt/observium
|
||||||
|
# ./adduser.php admin adminpassword 10
|
||||||
|
User admin added successfully.
|
||||||
|
|
||||||
|
下一步为发现和探寻任务设置一个 cron 任务,创建一个新的文件 ‘**/etc/cron.d/observium**’ 并在其中添加以下的内容。
|
||||||
|
|
||||||
|
33 */6 * * * root /opt/observium/discovery.php -h all >> /dev/null 2>&1
|
||||||
|
*/5 * * * * root /opt/observium/discovery.php -h new >> /dev/null 2>&1
|
||||||
|
*/5 * * * * root /opt/observium/poller-wrapper.py 1 >> /dev/null 2>&1
|
||||||
|
|
||||||
|
重载 cron 进程来增加新的任务。
|
||||||
|
|
||||||
|
# /etc/init.d/cron reload
|
||||||
|
|
||||||
|
好啦,你已经完成了 Observium 服务器的安装拉! 使用你的浏览器登录到 **http://\<Server IP>**,然后上路吧。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/Capture.png)
|
||||||
|
|
||||||
|
尽情享受吧!
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.unixmen.com/monitoring-network-servers-observium/
|
||||||
|
|
||||||
|
作者:[anismaj][a]
|
||||||
|
译者:[theo-l](http://github.com/theo-l)
|
||||||
|
校对:[wxy](http://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](http://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.unixmen.com/author/anis/
|
||||||
|
[1]:http://www.observium.org/
|
@ -1,10 +1,10 @@
|
|||||||
局域网中实现Ubuntu和Windows共享文件夹
|
如何在局域网中将Ubuntu文件夹共享给Windows
|
||||||
================================================================================
|
================================================================================
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_Folder_Ubuntu_windows.jpeg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_Folder_Ubuntu_windows.jpeg)
|
||||||
|
|
||||||
本文全面详细地向你描述了**在Ubuntu中如何实现局域网内的文件夹共享**。
|
本文全面详细地向你描述了**在Ubuntu中如何实现局域网内的文件夹共享**。
|
||||||
|
|
||||||
你的家中是不是有多台电脑?当你需要从一台Ubuntu电脑向另一台电脑传输数据时,是不是必须用到U盘或SD卡?你是否也觉得这个方法很烦人?我想肯定是。本文的目的就是使你在局域网内快速方便地传输文件、文档和其它较大的数据,来节省你的宝贵时间。只需一次设置,然后轻点鼠标,你就可以自由地**在Ubuntu和Windows之间共享文件**,当然这对其它Linux系统同样使用。不要担心这很容易操作,不会花费太多时间。
|
你的家中是不是有多台电脑?当你需要从一台Ubuntu电脑向另一台电脑传输数据时,是不是必须用到U盘或SD卡?你是否也觉得这个方法很烦人?我想肯定是。本文的目的就是使你在局域网内快速方便地传输文件、文档和其它较大的数据,以节省你的宝贵时间。只需一次设置,然后轻点鼠标,你就可以自由地**在Ubuntu和Windows之间共享文件**,当然这对其它Linux系统同样使用。不要担心,这很容易操作,不会花费太多时间。
|
||||||
|
|
||||||
除此之外,尽管本文是在Ubuntu上进行实践,但这个教程在其它Linux系统上同样有用。
|
除此之外,尽管本文是在Ubuntu上进行实践,但这个教程在其它Linux系统上同样有用。
|
||||||
|
|
||||||
@ -21,11 +21,11 @@
|
|||||||
|
|
||||||
#### 步骤一:####
|
#### 步骤一:####
|
||||||
|
|
||||||
为了在Ubuntu上实现局域网共享文件夹,右键点击打算共享的文件夹,并选择“Local Network Share”:
|
为了在Ubuntu上实现局域网共享文件夹,右键点击打算共享的文件夹,并选择“Local Network Share(本地网络共享)”:
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/Share_Folder_Ubuntu.jpeg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/Share_Folder_Ubuntu.jpeg)
|
||||||
|
|
||||||
**可能有用的故障方案**:如果在右键菜单中看不到“Local Network Share”的选项,那就新建一个终端,使用下面的命令去安装nautlius-share:
|
**可能有用的故障解决方案**:如果在右键菜单中看不到“Local Network Share”的选项,那就新建一个终端,使用下面的命令去安装nautlius-share插件:
|
||||||
|
|
||||||
sudo apt-get install nautilus-share
|
sudo apt-get install nautilus-share
|
||||||
|
|
||||||
@ -35,17 +35,17 @@
|
|||||||
|
|
||||||
#### 步骤二:####
|
#### 步骤二:####
|
||||||
|
|
||||||
一旦点击“Local Network Share”,就会出现共享文件夹的选项。只需选中“Share this folder”这一项:
|
一旦点击“Local Network Share”,就会出现共享文件夹的选项。只需选中“Share this folder(共享该文件夹)”这一项:
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_Folder_Ubuntu_1.jpeg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_Folder_Ubuntu_1.jpeg)
|
||||||
|
|
||||||
可能的故障方案:如果提示共享服务还未安装,就像下图所示,那就点击安装服务,按照提示操作。
|
**可能的故障解决方案**:如果提示共享服务还未安装,就像下图所示,那就点击安装服务,按照提示操作。
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_Folder_Ubuntu_2.jpeg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_Folder_Ubuntu_2.jpeg)
|
||||||
|
|
||||||
#### 步骤三:####
|
#### 步骤三:####
|
||||||
|
|
||||||
一旦选中“Share this folder”的选项,就会看到按钮“Create Share”变成可用了。你也可以允许其他用户在共享文件夹中编辑文件。选项“Guest access”也是如此。
|
当选中“Share this folder”的选项,就会看到按钮“Create Share(创建共享)”变得可以点击了。你也可以“Allow others to create and delete fies in this folder(允许其他用户在共享文件夹中编辑文件)”。选项“Guest access(允许访客访问)”也是如此。
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_folder_Ubuntu_3.png)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Share_folder_Ubuntu_3.png)
|
||||||
|
|
||||||
@ -55,13 +55,13 @@
|
|||||||
|
|
||||||
### 2. 在Ubuntu上使用密码保护实现局域网共享文件夹###
|
### 2. 在Ubuntu上使用密码保护实现局域网共享文件夹###
|
||||||
|
|
||||||
为了达到目的,首先需要配置Samba服务器。事实上,在这篇教程的前一部分我们已经用到了Samba,只是我们没有刻意强调。在介绍如何在Ubuntu上搭建Samba服务器实现局域网共享的方法之前,先快速预览一下[Samba][1]到底是什么。
|
为了达到这个目的,首先需要配置Samba服务器。事实上,在这篇教程的前一部分我们已经用到了Samba,只是我们没有刻意强调。在介绍如何在Ubuntu上搭建Samba服务器实现局域网共享的方法之前,先快速预览一下[Samba][1]到底是什么。
|
||||||
|
|
||||||
#### Samba是什么? ####
|
#### Samba是什么? ####
|
||||||
|
|
||||||
Samba是一个允许用户通过网络共享文件、文档和打印机的软件包,无论是在Linux、Windows,还是Mac上。它适用于所有的主流平台,可以在所有支持系统上流畅运行。下面是维基百科的介绍:
|
Samba是一个允许用户通过网络共享文件、文档和打印机的软件包,无论是在Linux、Windows,还是Mac上。它适用于所有的主流平台,可以在所有支持系统上流畅运行。下面是维基百科的介绍:
|
||||||
|
|
||||||
> Samba是一款重新实现SMB/CIFS网络协议的自由软件,最初由安德鲁·垂鸠开发。在第三版中,Smaba不仅支持通过不同的Windows客户端访问及分享SMB的文件夹及打印机,还可以集成到Windows Server域名,作为主要域名控制站(PDC)或者域名成员。它也可以作为Active Directory域名的一部分。
|
> Samba是一款重新实现SMB/CIFS网络协议的自由软件,最初由安德鲁·垂鸠开发。在第三版中,Smaba不仅支持通过不同的Windows客户端访问及分享SMB的文件夹及打印机,还可以集成到Windows Server域,作为主域控制器(PDC)或者域成员。它也可以作为活动目录域的一部分。
|
||||||
|
|
||||||
#### 在Ubuntu上安装Samba服务器 ####
|
#### 在Ubuntu上安装Samba服务器 ####
|
||||||
|
|
||||||
@ -77,7 +77,7 @@ Samba是一个允许用户通过网络共享文件、文档和打印机的软件
|
|||||||
|
|
||||||
#### 在Ubuntu上配置Samba服务器 ####
|
#### 在Ubuntu上配置Samba服务器 ####
|
||||||
|
|
||||||
从dash打开Samba配置工具:
|
从dash中打开Samba配置工具:
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/Setup-Samba.png)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/Setup-Samba.png)
|
||||||
|
|
||||||
@ -86,7 +86,7 @@ Samba是一个允许用户通过网络共享文件、文档和打印机的软件
|
|||||||
在Server Setting中可以看到两个选项卡,‘Basic’和‘Security’。在Basic选项卡下的选项含义如下:
|
在Server Setting中可以看到两个选项卡,‘Basic’和‘Security’。在Basic选项卡下的选项含义如下:
|
||||||
|
|
||||||
- 工作组 - 用户要连接的电脑所在工作组的名字。比如,如果你想连接到一台Windows电脑,你就要输入Windows电脑的工作组名字。在Windows的Samba服务器设置中,已经默认设置好统一的工作组名字。但如果你有不同的工作组名字,就在这个字段中输入自定义的工作组名字。(在Windows 7中获取工作组名字,右击计算机图标,进到属性,就能看到Windows工作组名字。)
|
- 工作组 - 用户要连接的电脑所在工作组的名字。比如,如果你想连接到一台Windows电脑,你就要输入Windows电脑的工作组名字。在Windows的Samba服务器设置中,已经默认设置好统一的工作组名字。但如果你有不同的工作组名字,就在这个字段中输入自定义的工作组名字。(在Windows 7中获取工作组名字,右击计算机图标,进到属性,就能看到Windows工作组名字。)
|
||||||
- 描述 - 其他用户看到的你的电脑名字。不要使用空格或计算机不支持(望更正!)的字符。
|
- 描述 - 其他用户看到的你的电脑名字。不要使用空格或不适用于网络的字符。
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/samba-server-settings.png)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/samba-server-settings.png)
|
||||||
|
|
||||||
@ -101,14 +101,14 @@ Samba是一个允许用户通过网络共享文件、文档和打印机的软件
|
|||||||
现在我们需要为网络共享文件创建一个系统用户。下面是非常简单的步骤:
|
现在我们需要为网络共享文件创建一个系统用户。下面是非常简单的步骤:
|
||||||
|
|
||||||
- 在Systems Settings下点击**User Accounts**。
|
- 在Systems Settings下点击**User Accounts**。
|
||||||
- 点击**unlock**使其可用,以及+(**plus**)图标。
|
- 点击**unlock**使其可用,以及+(**加号**)图标。
|
||||||
- 点击+(plus)图标,创建一个新的系统用户。
|
- 点击+(加号)图标,创建一个新的系统用户。
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/create-system-user1.jpg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/create-system-user1.jpg)
|
||||||
|
|
||||||
如上图所示,需要输入‘Full name’。当你输入‘Full name’时,Username会自动填充为Full name。因为创建这个用户是为了共享文件,所以还要指定Account Type为‘**Standard**’。
|
如上图所示,需要输入‘Full name’。当你输入‘Full name’时,Username会自动填充为Full name。因为创建这个用户是为了共享文件,所以还要指定Account Type为‘**Standard**’。
|
||||||
|
|
||||||
完成上述步骤,点击添加,你就创建好一个系统用户。这个用户还没有被激活,所以需要为其设置密码来激活。确保Users accounts界面已经解锁。点击Account disabled。输入一个新密码,然后确认密码,点击Change。
|
完成上述步骤,点击添加,你就创建好一个系统用户。这个用户还没有被激活,所以需要为其设置密码来激活。确保Users accounts界面已经解锁。点击尚不可用的账户,输入一个新密码,然后确认密码,点击Change。
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/activate-system-user.jpg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/activate-system-user.jpg)
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ Samba是一个允许用户通过网络共享文件、文档和打印机的软件
|
|||||||
|
|
||||||
#### 通过网络共享文件夹或文件 ####
|
#### 通过网络共享文件夹或文件 ####
|
||||||
|
|
||||||
在图形用户界面下通过Samba共享文件是很简单的。点击Plus图标,会看到如图所示的对话框:
|
在图形用户界面下通过Samba共享文件是很简单的。点击加号图标,会看到如图所示的对话框:
|
||||||
|
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/share-files-and-folders.jpg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/02/share-files-and-folders.jpg)
|
||||||
|
|
||||||
@ -157,9 +157,8 @@ Samba是一个允许用户通过网络共享文件、文档和打印机的软件
|
|||||||
|
|
||||||
全部搞定!我们也可以使用终端进行网络文件共享,但这样没有本文介绍的方法这么容易。如果你确实想知道命令行操作,我会再写一篇关于在Linux上使用命令行实现网络文件共享的文章。
|
全部搞定!我们也可以使用终端进行网络文件共享,但这样没有本文介绍的方法这么容易。如果你确实想知道命令行操作,我会再写一篇关于在Linux上使用命令行实现网络文件共享的文章。
|
||||||
|
|
||||||
所以,你是怎么找到这篇教程的呢?我希望看了这篇教程你可以**很容易地在Ubuntu和Windows之间共享文件**。如果你有任何问题或建议,请再评论里说出来。
|
所以,你是怎么找到这篇教程的呢?我希望看了这篇教程你可以**很容易地在Ubuntu和Windows之间共享文件**。如果你有任何问题或建议,请在评论里说出来。
|
||||||
|
|
||||||
这篇教程是在Kalc的请求下写出的。如果你也想,你可以[请求你自己的教程][2]。我们很乐意帮助你和面临同样问题的读者解决问题。
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -167,7 +166,7 @@ via: http://itsfoss.com/share-folders-local-network-ubuntu-windows/
|
|||||||
|
|
||||||
作者:[Mohd Sohail][a]
|
作者:[Mohd Sohail][a]
|
||||||
译者:[KayGuoWhu](https://github.com/KayGuoWhu)
|
译者:[KayGuoWhu](https://github.com/KayGuoWhu)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,8 +1,8 @@
|
|||||||
如何设置lftp - 一个简易的命令行FTP程序
|
LFTP : 一个功能强大的命令行FTP程序
|
||||||
================================================================================
|
================================================================================
|
||||||
大家好,这篇文章是介绍Lftp以及如何在Linux操作系统下安装的。[Lftp][1]是一个基于命令行的文件传输软件也被称为FTP客户端,由Alexander Lukyanov开发并以GNU GPL协议许可发行。除了FTP,它还支持FTPS,HTTP,HTTPS,HFTP,FISH,以及SFTP。这个程序还支持FXP,允许数据绕过客户端直接在两个FTP服务器之间传输。
|
大家好,这篇文章是介绍Lftp以及如何在Linux操作系统下安装的。[Lftp][1]是一个基于命令行的文件传输软件(也被称为FTP客户端),由Alexander Lukyanov开发并以GNU GPL协议许可发行。除了FTP协议外,它还支持FTPS,HTTP,HTTPS,HFTP,FISH,以及SFTP等协议。这个程序还支持FXP,允许数据绕过客户端直接在两个FTP服务器之间传输。
|
||||||
|
|
||||||
他有很多很棒的高级功能,比如完整目录树递归镜像以及断点续传下载。传输任务可以安排在稍后的时间段执行,可以限制带宽,可以创建传输列表,还支持类似Unix shell的任务控制。客户端还可以在交互式或自动脚本里使用。
|
它有很多很棒的高级功能,比如递归镜像整个目录树以及断点续传下载。传输任务可以安排在稍后的时间段计划执行,可以限制带宽,可以创建传输列表,还支持类似Unix shell的任务控制。客户端还可以在交互式或自动脚本里使用。
|
||||||
|
|
||||||
### 安装Lftp ###
|
### 安装Lftp ###
|
||||||
|
|
||||||
@ -44,7 +44,7 @@ OpenSuse系统里的包管理软件Zypper可以用来安装lftp。下面是在Op
|
|||||||
|
|
||||||
要登录到ftp服务器或sftp服务器,我们首先需要知道所要求的认证信息,比如用户名,密码,端口。
|
要登录到ftp服务器或sftp服务器,我们首先需要知道所要求的认证信息,比如用户名,密码,端口。
|
||||||
|
|
||||||
之后,我们想通过lftp来登录。
|
之后,我们可以通过lftp来登录。
|
||||||
|
|
||||||
$ lftp ftp://linoxide@localhost
|
$ lftp ftp://linoxide@localhost
|
||||||
|
|
||||||
@ -56,9 +56,9 @@ OpenSuse系统里的包管理软件Zypper可以用来安装lftp。下面是在Op
|
|||||||
|
|
||||||
![ftp login with ports](http://blog.linoxide.com/wp-content/uploads/2015/03/lftp-login-port.png)
|
![ftp login with ports](http://blog.linoxide.com/wp-content/uploads/2015/03/lftp-login-port.png)
|
||||||
|
|
||||||
### 浏览 ###
|
### 导航 ###
|
||||||
|
|
||||||
我们可以用**ls**命令来列出文件和目录,用**cd**命令打开目录。
|
我们可以用**ls**命令来列出文件和目录,用**cd**命令进入到目录。
|
||||||
|
|
||||||
![ls and cd](http://blog.linoxide.com/wp-content/uploads/2015/03/ls-cd-lftp.png)
|
![ls and cd](http://blog.linoxide.com/wp-content/uploads/2015/03/ls-cd-lftp.png)
|
||||||
|
|
||||||
@ -158,7 +158,7 @@ OpenSuse系统里的包管理软件Zypper可以用来安装lftp。下面是在Op
|
|||||||
|
|
||||||
### 总结 ###
|
### 总结 ###
|
||||||
|
|
||||||
哇!我们已经成功地安装了lftp并学会了使用它的一些基础的主要方式。lftp是一个非常棒的命令行ftp客户端,它支持许多额外的功能以及很酷的特性。它比其他普通ftp客户端多了很多东西。好吧,你要是有任何问题,建议,反馈,请在下面的评论区里留言。谢谢!享用lftp吧 :-)
|
哇!我们已经成功地安装了lftp并学会了它的一些基础的主要使用方式。lftp是一个非常棒的命令行ftp客户端,它支持许多额外的功能以及很酷的特性。它比其他普通ftp客户端多了很多东西。好吧,你要是有任何问题,建议,反馈,请在下面的评论区里留言。谢谢!享用lftp吧 :-)
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -166,7 +166,7 @@ via: http://linoxide.com/linux-how-to/setup-lftp-command-line-ftp/
|
|||||||
|
|
||||||
作者:[Arun Pyasi][a]
|
作者:[Arun Pyasi][a]
|
||||||
译者:[zpl1025](https://github.com/zpl1025)
|
译者:[zpl1025](https://github.com/zpl1025)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,82 @@
|
|||||||
|
Windows 下的免费 SSH 客户端工具
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
如果你的操作系统是 Windows,而你想要连接 Linux 服务器相互传送文件,那么你需要一个简称 SSH 的 Secure Shell 软件。实际上,SSH 是一个网络协议,它允许你通过网络连接到 Linux 和 Unix 服务器。SSH 使用公钥加密来认证远程的计算机。你可以有多种途径使用 SSH,无论是自动连接,还是使用密码认证登录。
|
||||||
|
|
||||||
|
本篇文章介绍了几种可以连接 Linux 服务器 SSH 客户端。
|
||||||
|
|
||||||
|
让我们开始。
|
||||||
|
|
||||||
|
### Putty ###
|
||||||
|
|
||||||
|
**Putty** 是最有名的 SSH 和 telnet 客户端,最初由 Simon Tatham 为 Windows 平台开发。Putty 是一款开源软件,有可用的源代码,和一群志愿者的开发和支持。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/putty.png)
|
||||||
|
|
||||||
|
Putty 非常易于安装和使用,通常大部分的配置选项你都不需要修改。你只需要输入少量基本的参数,就可以开始很简单地建立连接会话。[点此下载][1] Putty。
|
||||||
|
|
||||||
|
### Bitvise SSH Client ###
|
||||||
|
|
||||||
|
**Bitvise SSH** 是一款支持 SSH 和 SFTP 的 Windows 客户端。由 Bitvise 开发和提供专业支持。这款 SSH 客户端性能强悍,易于安装、便于使用。Bitvise SSH 客户端拥有功能丰富的图形界面,通过一个有自动重连功能的内置代理进行动态端口转发。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/bitvise.png)
|
||||||
|
|
||||||
|
Bitvise SSH 客户端对**个人用户使用是免费的**,同时对于在组织内部的个人商业使用也一样。你可以[在这里下载 Bitvise SSH 客户端][2]。
|
||||||
|
|
||||||
|
### MobaXterm ###
|
||||||
|
|
||||||
|
**MobaXterm** 是你的**远程计算的终极工具箱**。在一个 Windows 应用里,它为程序员、网管、IT 管理员及其它用户提供了精心裁剪的一揽子功能,让他们的远程操作变得简约时尚。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/mobaxterm.png)
|
||||||
|
|
||||||
|
MobaXterm 提供了所有重要的**远程网络工具** (如SSH、 X11、 RDP、 VNC、 FTP、 MOSH 等等),以及 Windows 桌面上的 **Unix 命令**(bash、 ls、 cat、sed、 grep、 awk、 rsync等等),而这些都是由一个开箱即用的**单一的便携程序**所提供。MobaXterm 对**个人使用免费**,你可以[在这里][3]下载 MobaXterm。
|
||||||
|
|
||||||
|
### DameWare SSH ###
|
||||||
|
|
||||||
|
我认为 **DameWare SSH** 是最好的免费SSH客户端。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/ssh.png)
|
||||||
|
|
||||||
|
这个免费工具是一个终端模拟器,可以让你从一个易用的控制台建立多个 telnet 和 SSH 连接。
|
||||||
|
|
||||||
|
-用一个带标签的控制台界面管理多个会话
|
||||||
|
-将常用的会话保存在 Windows 文件系统中
|
||||||
|
-使用多套保存的证书来轻松登录不同的设备
|
||||||
|
-使用 telnet、SSH1 和 SSH2 协议连接计算机和设备
|
||||||
|
|
||||||
|
你可以从[这个链接][4]下载 **DameWare SSH**。
|
||||||
|
|
||||||
|
### SmarTTY ###
|
||||||
|
|
||||||
|
SmarTTY 是一款免费的多标签 SSH 客户端,支持使用 SCP 命令随时复制文件和目录。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/smart.png)
|
||||||
|
|
||||||
|
大多数 SSH 服务器每个连接支持最多10个子会话.SmarTTY 在这方面做得很好:没有烦人的多个窗口,不需要重新登录,仅仅打开一个新的标签页就可以开始了!
|
||||||
|
|
||||||
|
### Cygwin ###
|
||||||
|
|
||||||
|
Cygwin 是一款 GNU 和开源工具的大杂烩,提供的功能近似于一个 Windows 平台下的 Linux。
|
||||||
|
|
||||||
|
![](http://www.unixmen.com/wp-content/uploads/2015/03/cyq.png)
|
||||||
|
|
||||||
|
**Cygwin** 包括了一个称为模拟库的 Unix 系统:cygwin.dll,集成了大量的 GNU 和其它的免费软件,以大量的可选包方式组织而成。在这些安装包中,有高质量的编译器和其他软件开发工具、一个X11服务器、一套完整的X11开发套件、GNU emacs 编辑器、Tex 和 LaTeX、openSSH(客户端和服务器),除此之外还有很多,包括在微软 Windows 下需要编译和使用 PhysioToolkit 软件的每一样东西。
|
||||||
|
|
||||||
|
读完我们的文章后,不知你中意哪一款 SSH 客户端?你可以留下你的评论,描述你喜欢的系统和选择的原因。当然,如果有另外的 SSH 客户端没有被本文列举出来,你可以帮助我们补充。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.unixmen.com/list-free-windows-ssh-client-tools-connect-linux-server/
|
||||||
|
|
||||||
|
作者:[anismaj][a]
|
||||||
|
译者:[wi-cuckoo](http://github.com/wi-cuckoo)
|
||||||
|
校对:[wxy](http://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](http://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.unixmen.com/author/anis/
|
||||||
|
[1]:http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html
|
||||||
|
[2]:http://www.bitvise.com/download-area
|
||||||
|
[3]:http://mobaxterm.mobatek.net/download.html
|
||||||
|
[4]:http://www.dameware.com/downloads/registration.aspx?productType=ssh&AppID=17471&CampaignID=70150000000PcNM
|
||||||
|
[5]:http://cygwin.com/packages/
|
@ -0,0 +1,132 @@
|
|||||||
|
5个有趣的Linux命令行技巧
|
||||||
|
================================================================================
|
||||||
|
你有将Linux物尽其用吗?对很多Linux用户来说,有很多看起来是技巧的有用特性。有些时候你会需要这些技巧。本文会帮助你更好得使用一些命令,发挥其更强大的功能。
|
||||||
|
|
||||||
|
![5个命令行技巧](http://www.tecmint.com/wp-content/uploads/2015/03/5-Command-Line-Tips.jpg)
|
||||||
|
|
||||||
|
*图1:5个命令行技巧*
|
||||||
|
|
||||||
|
我们开始一个新的系列,在这里我们还会写一些技巧,并且用尽量小的篇幅写清楚。
|
||||||
|
|
||||||
|
### 1. 我们可以使用[`history`命令][1]来查看曾经运行过的命令。 ###
|
||||||
|
|
||||||
|
这里是一个`history`命令的示例输出。
|
||||||
|
|
||||||
|
# history
|
||||||
|
|
||||||
|
![history命令例子](http://www.tecmint.com/wp-content/uploads/2015/03/history-command.gif)
|
||||||
|
|
||||||
|
*图2:history命令例子*
|
||||||
|
|
||||||
|
从`history`命令输出看,很明显,命令的执行时间没有被打出来。有解决方法吗?有的!运行如下命令:
|
||||||
|
|
||||||
|
# HISTTIMEFORMAT="%d/%m/%y %T "
|
||||||
|
# history
|
||||||
|
|
||||||
|
如果你想让这个修改永久生效,添加如下的一行内容到`~/.bashrc`文件中:
|
||||||
|
|
||||||
|
export HISTTIMEFORMAT="%d/%m/%y %T "
|
||||||
|
|
||||||
|
然后,在终端中运行:
|
||||||
|
|
||||||
|
# source ~/.bashrc
|
||||||
|
|
||||||
|
命令和选项的解释:
|
||||||
|
|
||||||
|
- history – 查看运行过的命令
|
||||||
|
- HISTIMEFORMAT – 设置时间格式的环境变量
|
||||||
|
- %d – 天
|
||||||
|
- %m – 月
|
||||||
|
- %y – 年
|
||||||
|
- %T – 时间戳
|
||||||
|
- source – 简而言之就是将文件内容发送给shell来执行
|
||||||
|
- .bashrc – BASH以交互方式启动时运行的脚本文件
|
||||||
|
|
||||||
|
![history命令输出的日志](http://www.tecmint.com/wp-content/uploads/2015/03/History-Command-Logs.gif)
|
||||||
|
|
||||||
|
*图3:`history`命令输出的日志*
|
||||||
|
|
||||||
|
### 2. 如何测试磁盘写入速度?###
|
||||||
|
|
||||||
|
一行`dd`命令脚本就可以实现。
|
||||||
|
|
||||||
|
# dd if=/dev/zero of=/tmp/output.img bs=8k count=256k conv=fdatasync; rm -rf /tmp/output.img
|
||||||
|
|
||||||
|
![dd命令例子](http://www.tecmint.com/wp-content/uploads/2015/03/dd-Command-Example.gif)
|
||||||
|
|
||||||
|
*图4:`dd`命令例子*
|
||||||
|
|
||||||
|
命令和选项的解释:
|
||||||
|
|
||||||
|
- dd – 转换和复制文件
|
||||||
|
- if=/dev/zero – 指定输入文件,默认为stdin(标准输入)
|
||||||
|
- of=/tmp/output.img – 指定输出文件,默认为stdout(标准输出)
|
||||||
|
- bs – 一次读和写的块大小,最大可以以MB为单位
|
||||||
|
- count – 复制次数
|
||||||
|
- conv – 使用逗号分隔的策略来转换文件(LCTT 译注:比如将大写字母转换成小写,echo AA | dd conv=lcase)
|
||||||
|
- rm – 删除文件和目录
|
||||||
|
- -rf – (-r) 递归地删除目录和其中的内容,(-f)强行删除而不输出确认信息
|
||||||
|
|
||||||
|
### 3. 你如何获取吃掉你磁盘空间的最大的6个文件?###
|
||||||
|
|
||||||
|
一个使用[`du`命令][2]的简单单行脚本即可实现,`du`命令主要用于获取文件的空间使用情况。
|
||||||
|
|
||||||
|
# du -hsx * | sort -rh | head -6
|
||||||
|
|
||||||
|
![获取磁盘空间使用情况的方法](http://www.tecmint.com/wp-content/uploads/2015/03/check-disk-space-usage.gif)
|
||||||
|
|
||||||
|
*图5:获取磁盘空间使用情况的方法*
|
||||||
|
|
||||||
|
命令和选项的解释:
|
||||||
|
|
||||||
|
- du – 估计文件的空间使用情况
|
||||||
|
- -hsx – (-h)更易读的格式,(-s)汇总输出,(-x)跳过其他文件系统的文件
|
||||||
|
- sort – 对文本文件按行排序
|
||||||
|
- -rf – (-r)将比较的结果逆序输出,(-f)忽略大小写
|
||||||
|
- head – 输出文件的头几行
|
||||||
|
|
||||||
|
### 4. 获取一个文件的详细状态信息###
|
||||||
|
|
||||||
|
可以使用`stat`命令
|
||||||
|
|
||||||
|
# stat filename_ext (例如:stat abc.pdf)
|
||||||
|
|
||||||
|
![获取文件的详细信息](http://www.tecmint.com/wp-content/uploads/2015/03/Check-File-Statistics.gif)
|
||||||
|
|
||||||
|
*图6:获取文件的详细信息*
|
||||||
|
|
||||||
|
### 5. 显示帮助 ###
|
||||||
|
|
||||||
|
最后一个技巧是为那些入门者准备的,如果你是有经验的用户,可能不需要它,除非你想从中寻找乐趣。入门者可能有Linux命令行恐惧症,下面的命令会随机显示一个man手册页。对入门者来说,好处是总会学到新的东西,而且不会厌倦。
|
||||||
|
|
||||||
|
# man $(ls /bin | shuf | head -1)
|
||||||
|
|
||||||
|
![查看随机的man手册页](http://www.tecmint.com/wp-content/uploads/2015/03/Generate-Random-Man-Pages.gif)
|
||||||
|
|
||||||
|
*图7:查看随机的man手册页*
|
||||||
|
|
||||||
|
命令和选项的解释:
|
||||||
|
|
||||||
|
- man – Linux man手册
|
||||||
|
- ls – 列出文件
|
||||||
|
- /bin – 系统可执行文件的路径
|
||||||
|
- shuf – 把输入内容按行随机打乱并输出
|
||||||
|
- head – 输出文件的头几行
|
||||||
|
|
||||||
|
这就是所有的内容了。如果你知道任何类似的技巧,可以分享给我们,我们会用你的语言在网站上发表出来。
|
||||||
|
|
||||||
|
不要忘记在下边评论框中留下有价值的反馈。保持联系。可以点赞或者将本文分享来帮助我们更好地传播内容。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.tecmint.com/5-linux-command-line-tricks/
|
||||||
|
|
||||||
|
作者:[Avishek Kumar][a]
|
||||||
|
译者:[goreliu](https://github.com/goreliu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.tecmint.com/author/avishek/
|
||||||
|
[1]:https://linux.cn/article-1143-1.html
|
||||||
|
[2]:http://www.tecmint.com/check-linux-disk-usage-of-files-and-directories/
|
@ -1,12 +1,13 @@
|
|||||||
如何在 Linux 中使用 Alpine 在命令行里获取 Gmail
|
如何在 Linux 中使用 Alpine 在命令行里访问 Gmail
|
||||||
================================================================================
|
================================================================================
|
||||||
假如你是一个命令行爱好者,我很确信你将张开双臂欢迎任何可以使你使用这个强大的工作环境来执行哪怕一项日常任务的工具,例如从 [安排日程][1] 、 [管理财务][2] 到 获取 [Facebook][3] 、[Twitter][4]等任务。
|
|
||||||
|
|
||||||
在这个帖子中,我将为你展示 Linux 命令行的另一个漂亮干练的使用案例:**获取 Google 的 Gmail 服务**,为此,我们将使用 Alpine,一个基于 ncurses 的多功能命令行邮件客户端(不要和 Alpine Linux 搞混淆)。我们将在 Alphine 中配置 Gmail 的 IMAP 和 SMTP 设定来通过 Google 的邮件服务器在终端环境中收取和发送邮件。在这个教程的最后,你将意识到只需几步就可以在 Alpine 中使用其他的邮件服务。
|
假如你是一个命令行爱好者,我很确信你会使用这个强大的工作环境来执行哪怕是一项日常任务的工具,并为之欢呼,例如从 [安排日程][1] 、 [管理财务][2] 到 获取 [Facebook][3] 、[Twitter][4]等任务。(LCTT 译注:阅读本文的另一个前提是,假如你还能访问 Gmail 或者知道 Gmail 是什么的话。)
|
||||||
|
|
||||||
诚然,已有许多卓越的基于 GUI 的邮件客户端存在,例如 Thunderbird, Evolution 或者甚至是 Web 界面,那么为什么还有人对使用命令行的邮件客户端来收取 Gmail 这样的事感兴趣呢?答案很简单。假如你需要快速地处理好事情并想避免使用不必要系统资源;或者你正工作在一个最小化安装(注:这里我感觉自己翻译有误)的服务器上,而它没有安装 X 服务(注:这里也需要更改);又或者是 X 服务在你的桌面上崩溃了,而你需要在解决这个问题之前急切地发送一些邮件。在上述所有的情况下, Alpine 都可以派上用场并在任何时间满足你的需求。
|
在这个帖子中,我将为你展示 Linux 命令行的另一个漂亮干练的使用案例:**访问 Google 的 Gmail 服务**,为此,我们将使用 Alpine,一个基于 ncurses 的多功能命令行邮件客户端(不要和 Alpine Linux 搞混淆)。我们将在 Alphine 中配置 Gmail 的 IMAP 和 SMTP 设定,通过 Google 的邮件服务器在终端环境中收取和发送邮件。在这个教程的最后,你将发现只需几步就可以在 Alpine 中使用其他的邮件服务。
|
||||||
|
|
||||||
除了简单的编辑,发送和接收文本类的邮件信息等功能外, Alpine 还可以进行加密,解密和对邮件信息进行数字签名,以及与 TLS(注:Transport Layer Security) 无缝集成。
|
诚然,已有许多卓越的基于 GUI 的邮件客户端存在,例如 Thunderbird, Evolution 或者甚至是 Web 界面,那么为什么还有人对使用命令行的邮件客户端来收取 Gmail 这样的事感兴趣呢?答案很简单。假如你需要快速地处理好事情并想避免浪费不必要系统资源;或者你正工作在一个精简安装无操作台的服务器上,它没有安装用于图形显示的 X 服务;又或者是 X 服务在你的桌面上崩溃了,而你需要在解决这个问题之前急切地发送一些邮件。在上述所有的情况下, Alpine 都可以派上用场并在任何时间满足你的需求。
|
||||||
|
|
||||||
|
除了简单的编辑,发送和接收文本类的邮件信息等功能外, Alpine 还可以进行加密,解密和对邮件信息进行数字签名,以及与 TLS(注:Transport Layer Security,传输层加密)无缝集成。
|
||||||
|
|
||||||
### 在 Linux 上安装 Alpine ###
|
### 在 Linux 上安装 Alpine ###
|
||||||
|
|
||||||
@ -22,16 +23,13 @@
|
|||||||
|
|
||||||
# alpine
|
# alpine
|
||||||
|
|
||||||
在你第一次启用 Alpine 时,它将在当前用户的家目录下创建一个邮件文件夹(`~/mail`),并显现出主界面,正如下面的截屏所显示的那样:
|
在你第一次启用 Alpine 时,它将在当前用户的家目录下创建一个邮件文件夹(`~/mail`),并显现出主界面,正如下面的视频所显示的那样:YOUTUBU 视频 - http://www.youtube.com/kuKiv3uze4U 。
|
||||||
|
|
||||||
注:youtube视频,发布的时候做个链接吧(注:这里我不知道该如何操作,不过我已经下载了该视频,如有需要,可以发送)
|
|
||||||
<iframe width="615" height="346" frameborder="0" allowfullscreen="" src="http://www.youtube.com/embed/kuKiv3uze4U?feature=oembed"></iframe>
|
|
||||||
|
|
||||||
它的用户界面有下列几个模块:
|
它的用户界面有下列几个模块:
|
||||||
|
|
||||||
![](https://farm9.staticflickr.com/8724/16618079590_6c236ce2c2_c.jpg)
|
![](https://farm9.staticflickr.com/8724/16618079590_6c236ce2c2_c.jpg)
|
||||||
|
|
||||||
请随意地浏览,操作来熟悉 Alpine。你总是可以在任何时候通过敲 'Q' 来回到命令提示符界面。请注意,所有的字符界面下方都有与操作相关的帮助。
|
请随意地浏览、操作来熟悉 Alpine。你总是可以在任何时候通过敲 'Q' 来回到命令提示符界面。请注意,所有的字符界面下方都有与操作相关的帮助。
|
||||||
|
|
||||||
在进一步深入之前,我们将为 Alpine 创建一个默认的配置文件。为此,请关闭 Alpine,然后在命令行中执行下面的命令:
|
在进一步深入之前,我们将为 Alpine 创建一个默认的配置文件。为此,请关闭 Alpine,然后在命令行中执行下面的命令:
|
||||||
|
|
||||||
@ -39,9 +37,9 @@
|
|||||||
|
|
||||||
### 配置 Alpine 来使用 Gmail 账号 ###
|
### 配置 Alpine 来使用 Gmail 账号 ###
|
||||||
|
|
||||||
一旦你安装了 Alpine 并至少花费了几分钟的时间来熟悉它的界面和菜单,下面便是实际配置它来使用一个已有的 Gmail 账户的时候了。
|
当你安装了 Alpine 并至少花费了几分钟的时间来熟悉它的界面和菜单,下面便是实际配置它来使用一个已有的 Gmail 账户的时候了。
|
||||||
|
|
||||||
在 Alpine 中执行下面的步骤之前,记得要通过你的 Web 邮件界面,在你的 Gmail 设定里启用 IMAP 协议。一旦在你的 Gmail 账户中 IMAP 被启用,执行下面的步骤来在 Alpine 中启用阅读 Gmail 信息的功能。
|
在 Alpine 中执行下面的步骤之前,记得首先要通过你的 Web 邮件界面,在你的 Gmail 设定里启用 IMAP 协议。一旦在你的 Gmail 账户中启用了 IMAP ,执行下面的步骤来在 Alpine 中启用阅读 Gmail 信息的功能。
|
||||||
|
|
||||||
首先,启动 Alpine。
|
首先,启动 Alpine。
|
||||||
|
|
||||||
@ -51,12 +49,12 @@
|
|||||||
|
|
||||||
按 'A' 来新建一个文件夹并填写必要的信息:
|
按 'A' 来新建一个文件夹并填写必要的信息:
|
||||||
|
|
||||||
- **昵称**: 填写任何你想写的名字;
|
- **Nickname**: 填写任何你想写的名字;
|
||||||
- **服务器**: imap.gmail.com/ssl/user=yourgmailusername@gmail.com
|
- **Server**: imap.gmail.com/ssl/user=yourgmailusername@gmail.com
|
||||||
|
|
||||||
你可以将 `Path` 和 `View` 留白不填。
|
你可以将 `Path` 和 `View` 留白不填。
|
||||||
|
|
||||||
然后按 `Ctrl+X` 并在有提示时输入你的 Gmail 密码:
|
然后按 `Ctrl+X` 并在提示时输入你的 Gmail 密码:
|
||||||
|
|
||||||
![](https://farm9.staticflickr.com/8611/16618079640_6f7dca336a_b.jpg)
|
![](https://farm9.staticflickr.com/8611/16618079640_6f7dca336a_b.jpg)
|
||||||
|
|
||||||
@ -64,7 +62,7 @@
|
|||||||
|
|
||||||
![](https://farm8.staticflickr.com/7598/16804355052_10c1a6c5bd_b.jpg)
|
![](https://farm8.staticflickr.com/7598/16804355052_10c1a6c5bd_b.jpg)
|
||||||
|
|
||||||
为了验证,你可以比较在 Alpine 中显示的 "Gmail Sent" 信箱和在 Web 界面下的信箱:
|
要验证的话,你可以比较在 Alpine 中显示的 "Gmail Sent" 信箱和在 Web 界面下的信箱:
|
||||||
|
|
||||||
![](https://farm8.staticflickr.com/7602/16619323939_d2eab3e162_c.jpg)
|
![](https://farm8.staticflickr.com/7602/16619323939_d2eab3e162_c.jpg)
|
||||||
|
|
||||||
@ -73,7 +71,7 @@
|
|||||||
# The approximate number of seconds between checks for new mail
|
# The approximate number of seconds between checks for new mail
|
||||||
mail-check-interval=10
|
mail-check-interval=10
|
||||||
|
|
||||||
最后,我们需要配置一个 SMTP 服务器来通过 Alpine 发送邮件信息。回到先前解释过的 Alpine 的设置界面,然后按 'C' 来设定一个 Google 的 SMTP 服务器地址,你需要像下面这样编辑 `SMTP Server`(为了发送) 这一行内容:
|
最后,我们需要配置一个 SMTP 服务器来通过 Alpine 发送邮件。回到先前解释过的 Alpine 的设置界面,然后按 'C' 来设定一个 Google 的 SMTP 服务器地址,你需要像下面这样编辑 `SMTP Server`(用于发送邮件)这一行内容:
|
||||||
|
|
||||||
smtp.gmail.com:587/tls/user=yourgmailusername@gmail.com
|
smtp.gmail.com:587/tls/user=yourgmailusername@gmail.com
|
||||||
|
|
||||||
@ -81,7 +79,7 @@
|
|||||||
|
|
||||||
### 总结 ###
|
### 总结 ###
|
||||||
|
|
||||||
在这个帖子里,我们讨论了在终端环境中如何通过一个名为 Alpha 的轻量且强大的命令行邮件客户端来获取 Gmail。 Alpine 是一个发布在 Apache Software License 2.0 协议下的自由软件,该协议与 GPL 协议相兼容。 Alpine 引以自豪的是:它不仅对新手友好,同时还做到了让那些经验丰富的系统管理员认为它是强大的。我希望在你阅读完这篇文章后,你能意识到我最后一个论断是多么的正确。
|
在这个帖子里,我们讨论了在终端环境中如何通过一个名为 Alpine 的轻量且强大的命令行邮件客户端来访问 Gmail。 Alpine 是一个发布在 Apache Software License 2.0 协议下的自由软件,该协议与 GPL 协议相兼容。 Alpine 引以自豪的是:它不仅对新手友好,同时还做到了让那些经验丰富的系统管理员认为它是强大的。我希望在你阅读完这篇文章后,你能意识到我最后一个论断是多么的正确。
|
||||||
|
|
||||||
非常欢迎使用下面的输入框来留下你的评论或问题。我期待着你们的反馈!
|
非常欢迎使用下面的输入框来留下你的评论或问题。我期待着你们的反馈!
|
||||||
|
|
||||||
@ -91,7 +89,7 @@ via: http://xmodulo.com/gmail-command-line-linux-alpine.html
|
|||||||
|
|
||||||
作者:[Gabriel Cánepa][a]
|
作者:[Gabriel Cánepa][a]
|
||||||
译者:[FSSlc](https://github.com/FSSlc)
|
译者:[FSSlc](https://github.com/FSSlc)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
@ -100,4 +98,4 @@ via: http://xmodulo.com/gmail-command-line-linux-alpine.html
|
|||||||
[2]:http://xmodulo.com/manage-personal-expenses-command-line.html
|
[2]:http://xmodulo.com/manage-personal-expenses-command-line.html
|
||||||
[3]:http://xmodulo.com/access-facebook-command-line-linux.html
|
[3]:http://xmodulo.com/access-facebook-command-line-linux.html
|
||||||
[4]:http://xmodulo.com/access-twitter-command-line-linux.html
|
[4]:http://xmodulo.com/access-twitter-command-line-linux.html
|
||||||
[5]:http://xmodulo.com/how-to-set-up-epel-repository-on-centos.html
|
[5]:https://linux.cn/article-2324-1.html
|
@ -1,12 +1,13 @@
|
|||||||
走进Linux之systemd启动过程
|
走进Linux之systemd启动过程
|
||||||
================================================================================
|
================================================================================
|
||||||
Linux系统的启动方式有点复杂,而且总是有需要优化的地方。传统的Linux系统启动过程主要由著名的init进程(也被称为SysV init启动系统)处理,而基于init的启动系统也被确认会有效率不足的问题,systemd是Linux系统机器的另一种启动方式,宣称弥补了以[传统Linux SysV init][2]为基础的系统的缺点。在这里我们将着重讨论systemd的特性和争议,但是为了更好地理解它,也会看一下通过传统的以SysV init为基础的系统的Linux启动过程是什么样的。友情提醒一下systemd仍然处在测试阶段,而未来发布的Linux操作系统也正准备用systemd启动管理程序替代当前的启动过程。
|
|
||||||
|
Linux系统的启动方式有点复杂,而且总是有需要优化的地方。传统的Linux系统启动过程主要由著名的init进程(也被称为SysV init启动系统)处理,而基于init的启动系统被认为有效率不足的问题,systemd是Linux系统机器的另一种启动方式,宣称弥补了以[传统Linux SysV init][2]为基础的系统的缺点。在这里我们将着重讨论systemd的特性和争议,但是为了更好地理解它,也会看一下通过传统的以SysV init为基础的系统的Linux启动过程是什么样的。友情提醒一下,systemd仍然处在测试阶段,而未来发布的Linux操作系统也正准备用systemd启动管理程序替代当前的启动过程(LCTT 译注:截止到本文发表,主流的Linux发行版已经有很多采用了 systemd)。
|
||||||
|
|
||||||
### 理解Linux启动过程 ###
|
### 理解Linux启动过程 ###
|
||||||
|
|
||||||
在我们打开Linux电脑的电源后第一个启动的进程就是init。分配给init进程的PID是1。它是系统其他所有进程的父进程。当一台Linux电脑启动后,处理器会先在系统存储中查找BIOS,之后BIOS会测试系统资源然后找到第一个引导设备,通常设置为硬盘,然后会查找硬盘的主引导记录(MBR),然后加载到内存中并把控制权交给它,以后的启动过程就由MBR控制。
|
在我们打开Linux电脑的电源后第一个启动的进程就是init。分配给init进程的PID是1。它是系统其他所有进程的父进程。当一台Linux电脑启动后,处理器会先在系统存储中查找BIOS,之后BIOS会检测系统资源然后找到第一个引导设备,通常为硬盘,然后会查找硬盘的主引导记录(MBR),然后加载到内存中并把控制权交给它,以后的启动过程就由MBR控制。
|
||||||
|
|
||||||
主引导记录会初始化引导程序(Linux上有两个著名的引导程序,GRUB和LILO,80%的Linux系统在用GRUB引导程序),这个时候GRUB或LILO会加载内核模块。内核会马上查找/sbin下的init进程并执行它。从这里开始init成为了Linux系统的父进程。init读取的第一个文件是/etc/inittab,通过它init会确定我们Linux操作系统的运行级别。它会从文件/etc/fstab里查找分区表信息然后做相应的挂载。然后init会启动/etc/init.d里指定的默认启动级别的所有服务/脚本。所有服务在这里通过init一个一个被初始化。在这个过程里,init每次只启动一个服务,所有服务/守护进程都在后台执行并由init来管理。
|
主引导记录会初始化引导程序(Linux上有两个著名的引导程序,GRUB和LILO,80%的Linux系统在用GRUB引导程序),这个时候GRUB或LILO会加载内核模块。内核会马上查找/sbin下的“init”程序并执行它。从这里开始init成为了Linux系统的父进程。init读取的第一个文件是/etc/inittab,通过它init会确定我们Linux操作系统的运行级别。它会从文件/etc/fstab里查找分区表信息然后做相应的挂载。然后init会启动/etc/init.d里指定的默认启动级别的所有服务/脚本。所有服务在这里通过init一个一个被初始化。在这个过程里,init每次只启动一个服务,所有服务/守护进程都在后台执行并由init来管理。
|
||||||
|
|
||||||
关机过程差不多是相反的过程,首先init停止所有服务,最后阶段会卸载文件系统。
|
关机过程差不多是相反的过程,首先init停止所有服务,最后阶段会卸载文件系统。
|
||||||
|
|
||||||
@ -14,9 +15,9 @@ Linux系统的启动方式有点复杂,而且总是有需要优化的地方。
|
|||||||
|
|
||||||
### 理解Systemd ###
|
### 理解Systemd ###
|
||||||
|
|
||||||
开发Systemd的主要目的就是减少系统引导时间和计算开销。Systemd(系统管理守护进程),最开始以GNU GPL协议授权开发,现在已转为使用GNU LGPL协议,它是如今讨论最热烈的引导和服务管理程序。如果你的Linux系统配置为使用Systemd引导程序,那么代替传统的SysV init,启动过程将交给systemd处理。Systemd的一个核心功能是它同时支持SysV init的后开机启动脚本。
|
开发Systemd的主要目的就是减少系统引导时间和计算开销。Systemd(系统管理守护进程),最开始以GNU GPL协议授权开发,现在已转为使用GNU LGPL协议,它是如今讨论最热烈的引导和服务管理程序。如果你的Linux系统配置为使用Systemd引导程序,它取替传统的SysV init,启动过程将交给systemd处理。Systemd的一个核心功能是它同时支持SysV init的后开机启动脚本。
|
||||||
|
|
||||||
Systemd引入了并行启动的概念,它会为每个需要启动的守护进程建立一个管道套接字,这些套接字对于使用它们的进程来说是抽象的,这样它们可以允许不同守护进程之间进行交互。Systemd会创建新进程并为每个进程分配一个控制组。处于不同控制组的进程之间可以通过内核来互相通信。[systemd处理开机启动进程][2]的方式非常漂亮,和传统基于init的系统比起来优化了太多。让我们看下Systemd的一些核心功能。
|
Systemd引入了并行启动的概念,它会为每个需要启动的守护进程建立一个套接字,这些套接字对于使用它们的进程来说是抽象的,这样它们可以允许不同守护进程之间进行交互。Systemd会创建新进程并为每个进程分配一个控制组(cgroup)。处于不同控制组的进程之间可以通过内核来互相通信。[systemd处理开机启动进程][2]的方式非常漂亮,和传统基于init的系统比起来优化了太多。让我们看下Systemd的一些核心功能。
|
||||||
|
|
||||||
- 和init比起来引导过程简化了很多
|
- 和init比起来引导过程简化了很多
|
||||||
- Systemd支持并发引导过程从而可以更快启动
|
- Systemd支持并发引导过程从而可以更快启动
|
||||||
@ -81,7 +82,9 @@ Systemd提供了工具用于识别和定位引导相关的问题或性能影响
|
|||||||
234ms httpd.service
|
234ms httpd.service
|
||||||
191ms vmms.service
|
191ms vmms.service
|
||||||
|
|
||||||
**systemd-analyze verify** 显示在所有系统单元中是否有语法错误。**systemd-analyze plot** 可以用来把整个引导过程写入一个SVG格式文件里。整个引导过程非常长不方便阅读,所以通过这个命令我们可以把输出写入一个文件,之后再查看和分析。下面这个命令就是做这个。
|
**systemd-analyze verify** 显示在所有系统单元中是否有语法错误。
|
||||||
|
|
||||||
|
**systemd-analyze plot** 可以用来把整个引导过程写入一个SVG格式文件里。整个引导过程非常长不方便阅读,所以通过这个命令我们可以把输出写入一个文件,之后再查看和分析。下面这个命令就是做这个。
|
||||||
|
|
||||||
systemd-analyze plot > boot.svg
|
systemd-analyze plot > boot.svg
|
||||||
|
|
||||||
@ -89,9 +92,9 @@ Systemd提供了工具用于识别和定位引导相关的问题或性能影响
|
|||||||
|
|
||||||
Systemd并没有幸运地获得所有人的青睐,一些专家和管理员对于它的工作方式和开发有不同意见。根据对于Systemd的批评,它不是“类Unix”方式因为它试着替换一些系统服务。一些专家也不喜欢使用二进制配置文件的想法。据说编辑systemd配置非常困难而且没有一个可用的图形工具。
|
Systemd并没有幸运地获得所有人的青睐,一些专家和管理员对于它的工作方式和开发有不同意见。根据对于Systemd的批评,它不是“类Unix”方式因为它试着替换一些系统服务。一些专家也不喜欢使用二进制配置文件的想法。据说编辑systemd配置非常困难而且没有一个可用的图形工具。
|
||||||
|
|
||||||
### 在Ubuntu 14.04和12.04上测试Systemd ###
|
### 如何在Ubuntu 14.04和12.04上测试Systemd ###
|
||||||
|
|
||||||
本来,Ubuntu决定从Ubuntu 16.04 LTS开始使用Systemd来替换当前的引导过程。Ubuntu 16.04预计在2016年4月发布,但是考虑到Systemd的流行和需求,即将发布的**Ubuntu 15.04**将采用它作为默认引导程序。好消息是Ubuntu 14.04 Trusty Tahr和Ubuntu 12.04 Precise Pangolin的用户可以在他们的机器上测试Systemd。测试过程并不复杂,你所要做的只是把相关的PPA包含到系统中,更新仓库并升级系统。
|
本来,Ubuntu决定从Ubuntu 16.04 LTS开始使用Systemd来替换当前的引导过程。Ubuntu 16.04预计在2016年4月发布,但是考虑到Systemd的流行和需求,刚刚发布的**Ubuntu 15.04**采用它作为默认引导程序。另外,Ubuntu 14.04 Trusty Tahr和Ubuntu 12.04 Precise Pangolin的用户可以在他们的机器上测试Systemd。测试过程并不复杂,你所要做的只是把相关的PPA包含到系统中,更新仓库并升级系统。
|
||||||
|
|
||||||
**声明**:请注意它仍然处于Ubuntu的测试和开发阶段。升级测试包可能会带来一些未知错误,最坏的情况下有可能损坏你的系统配置。请确保在尝试升级前已经备份好重要数据。
|
**声明**:请注意它仍然处于Ubuntu的测试和开发阶段。升级测试包可能会带来一些未知错误,最坏的情况下有可能损坏你的系统配置。请确保在尝试升级前已经备份好重要数据。
|
||||||
|
|
||||||
@ -127,7 +130,7 @@ Systemd并没有幸运地获得所有人的青睐,一些专家和管理员对
|
|||||||
|
|
||||||
![](http://blog.linoxide.com/wp-content/uploads/2015/03/Grub-Systemd.png)
|
![](http://blog.linoxide.com/wp-content/uploads/2015/03/Grub-Systemd.png)
|
||||||
|
|
||||||
就这样,你的Ubuntu系统已经不在使用传统的引导程序了,改为使用Systemd管理器。重启你的机器然后查看systemd引导过程吧。
|
就这样,你的Ubuntu系统已经不再使用传统的引导程序了,改为使用Systemd管理器。重启你的机器然后查看systemd引导过程吧。
|
||||||
|
|
||||||
![](http://blog.linoxide.com/wp-content/uploads/2015/03/Sytemd-Boot.png)
|
![](http://blog.linoxide.com/wp-content/uploads/2015/03/Sytemd-Boot.png)
|
||||||
|
|
||||||
@ -141,7 +144,7 @@ via: http://linoxide.com/linux-how-to/systemd-boot-process/
|
|||||||
|
|
||||||
作者:[Aun Raza][a]
|
作者:[Aun Raza][a]
|
||||||
译者:[zpl1025](https://github.com/zpl1025)
|
译者:[zpl1025](https://github.com/zpl1025)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,144 @@
|
|||||||
|
如何在Fedora或CentOS上使用Samba共享文件夹
|
||||||
|
================================================================================
|
||||||
|
如今,无论在家里或者是办公场所,不同的电脑之间共享文件夹已不是什么新鲜事了。在这种趋势下,现代操作系统通过网络文件系统的方式使得电脑间数据的交换变得简单而透明。如果您工作的环境中既有微软的Windows又有Linux,那么,一个共享文件及目录的方式便是通过一个跨平台网络文件共享协议:SMB/CIFS。Windows原生的支持SMB/CIFS,Linux也通过开源的软件Samba实现了SMB/CIFS协议。
|
||||||
|
|
||||||
|
在这篇文章中,我们将展示**如何使用Samba共享文件夹**。我们使用的Linux平台是**Fedora或CentOS**。这篇文章分为四部分。首先,我们在Fedora/CentOS环境下安装Sambe。接着,我们讨论如何调整SELinux和防火墙配置以允许Samba的文件共享。最后我们介绍如何使用Samba来共享文件夹。
|
||||||
|
|
||||||
|
### 步骤1:在Fedora和CentOS上安装Samba ###
|
||||||
|
|
||||||
|
首先,安装Samba以及进行一些基本的配置。
|
||||||
|
|
||||||
|
检验Samba是否已经安装在您的系统中:
|
||||||
|
|
||||||
|
$ rpm -q samba samba-common samba-client
|
||||||
|
|
||||||
|
如果上面的命令没有任何输出,这意味着Samba并未安装。这时,应使用下面的命令来安装Samba。
|
||||||
|
|
||||||
|
$ sudo yum install samba samba-common samba-client
|
||||||
|
|
||||||
|
接下来,创建一个用于在网络中共享的本地文件夹。这个文件夹应该以Samba共享的方式导出到远程的用户。在这个指南中,我们会在顶层文件夹'/'中创建这个文件夹,因此,请确保您有相应的权限。
|
||||||
|
|
||||||
|
$ sudo mkdir /shared
|
||||||
|
|
||||||
|
如果您想在您的home文件夹内创建共享文件夹(例如,~/shared),您必须激活SELinux中Samba的home文件夹共享选项,具体将在后面提到。
|
||||||
|
|
||||||
|
在创建/shared文件夹后,设置文件夹权限以保证其余用户可以访问它。
|
||||||
|
|
||||||
|
$ sudo chmod o+rw /shared
|
||||||
|
|
||||||
|
如果您不想其他用户对该文件夹拥有写权限,您需要移除命令中的'w'选项。
|
||||||
|
|
||||||
|
$ sudo chmod o+r /shared
|
||||||
|
|
||||||
|
接下来,创建一个空文件来测试。这个文件可以被用来验证Samba的共享已经被挂载。
|
||||||
|
|
||||||
|
$ sudo touch /shared/file1
|
||||||
|
|
||||||
|
### 步骤2:为Samba配置SELinux ###
|
||||||
|
|
||||||
|
接下来,我们需要再次配置SELinux。在Fedora和CentOS发行版中SELinux是默认开启的。SELinux仅在正确的安全配置下才允许Samba读取和修改文件或文件夹。(例如,加上'samba_share_t'属性标签)。
|
||||||
|
|
||||||
|
下面的命令为文件的配置添加必要的标签:
|
||||||
|
|
||||||
|
$ sudo semanage fcontext -a -t samba_share_t "<directory>(/.*)?"
|
||||||
|
|
||||||
|
将<directory>替换为我们之前为Samba共享创建的本地文件夹(例如,/shared):
|
||||||
|
|
||||||
|
$ sudo semanage fcontext -a -t samba_share_t "/shared(/.*)?"
|
||||||
|
|
||||||
|
我们必须执行restorecon命令来激活修改的标签,命令如下:
|
||||||
|
|
||||||
|
$ sudo restorecon -R -v /shared
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8584/16652774078_2055f45f70_b.jpg)
|
||||||
|
|
||||||
|
为了通过Samba共享在我们home文件夹内的文件夹,我们必须在SELinux中开启共享home文件夹的选项,该选项默认被关闭。下面的命令能达到该效果。如果您并未共享您的home文件夹,那么您可以跳过该步骤。
|
||||||
|
|
||||||
|
$ sudo setsebool -P samba_enable_home_dirs 1
|
||||||
|
|
||||||
|
### 步骤3:为Samba配置防火墙 ###
|
||||||
|
|
||||||
|
下面的命令用来打开防火墙中Samba共享所需的TCP/UDP端口。
|
||||||
|
|
||||||
|
如果您在使用firewalld(例如,在Fedora和CentOS7下),接下来的命令将会永久的修改Samba相关的防火墙规则。
|
||||||
|
|
||||||
|
$ sudo firewall-cmd --permanent --add-service=samba
|
||||||
|
|
||||||
|
如果您在防火墙中使用iptables(例如,CentOS6或者更早的版本),可以使用下面的命令来打开Samba必要的向外的端口。
|
||||||
|
|
||||||
|
$ sudo vi /etc/sysconfig/iptables
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 445 -j ACCEPT
|
||||||
|
-A RH-Firewall-1-INPUT -m state --state NEW -m udp -p udp --dport 445 -j ACCEPT
|
||||||
|
-A RH-Firewall-1-INPUT -m state --state NEW -m udp -p udp --dport 137 -j ACCEPT
|
||||||
|
-A RH-Firewall-1-INPUT -m state --state NEW -m udp -p udp --dport 138 -j ACCEPT
|
||||||
|
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 139 -j ACCEPT
|
||||||
|
|
||||||
|
然后重启iptables服务:
|
||||||
|
|
||||||
|
$ sudo service iptables restart
|
||||||
|
|
||||||
|
### 步骤4:更改Samba配置 ###
|
||||||
|
|
||||||
|
后面的步骤用来配置Samba以将本地文件夹导出为Samba共享文件夹。
|
||||||
|
|
||||||
|
使用文件编辑器打开Samba配置文件,并将下面的行添加到文件的末尾。
|
||||||
|
|
||||||
|
$ sudo nano /etc/samba/smb.conf
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
[myshare]
|
||||||
|
comment=my shared files
|
||||||
|
path=/shared
|
||||||
|
public=yes
|
||||||
|
writeable=yes
|
||||||
|
|
||||||
|
上面在括号内的文本(例如,"myshare")是Samba共享的资源的名字,它被用来从远程主机存取Samba共享。
|
||||||
|
|
||||||
|
创建Samba用户帐户,这是挂载和导出Samba文件系统所必须的。我们可以使用smbpasswd工具来创建一个Samba用户。注意,Samba用户帐户必须是已有的Linux用户。如果您尝试使用smbpasswd添加一个不存在的用户,它会返回一个错误的消息。
|
||||||
|
|
||||||
|
如果您不想使用任何已存在的Linux用户作为Samba用户,您可以在您的系统中创建一个新的用户。为安全起见,设置新用户的登录脚本为/sbin/nologin,并且不创建该用户的home文件夹。
|
||||||
|
|
||||||
|
在这个例子中,我们创建了一个名叫"sambaguest"的用户,如下:
|
||||||
|
|
||||||
|
$ sudo useradd -M -s /sbin/nologin sambaguest
|
||||||
|
$ sudo passwd sambaguest
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8702/16814479366_53f540d3ba_b.jpg)
|
||||||
|
|
||||||
|
在创建一个新用户后,使用smbpasswd命令添加Samba用户。当这个命令询问一个密码时,您可以键入一个与其用户密码不同的密码。
|
||||||
|
|
||||||
|
$ sudo smbpasswd -a sambaguest
|
||||||
|
|
||||||
|
激活Samba服务,并检测Samba服务是否在运行。
|
||||||
|
|
||||||
|
$ sudo systemctl enable smb.service
|
||||||
|
$ sudo systemctl start smb.service
|
||||||
|
$ sudo systemctl is-active smb
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7607/16652984770_622f24bccc_b.jpg)
|
||||||
|
|
||||||
|
使用下面的命令来查看Samba中共享的文件夹列表。
|
||||||
|
|
||||||
|
$ smbclient -U sambaguest -L localhost
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7281/16220411103_06bf585901_b.jpg)
|
||||||
|
|
||||||
|
接下来是在Thunar文件管理器中访问Samba共享文件夹以及对file1进行拷贝复制的截图。注意,Samba的共享内容可以通过在Thunar中通过 `smb://<samba-server-IP-address>/myshare` 这个地址来访问。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7644/16218011174_c8b34fcedc_b.jpg)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/share-directory-samba-fedora-centos.html
|
||||||
|
|
||||||
|
作者:[Kristophorus Hadiono][a]
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/kristophorus
|
@ -0,0 +1,159 @@
|
|||||||
|
Sleuth Kit:一个用来分析磁盘映像和恢复文件的开源取证工具
|
||||||
|
================================================================================
|
||||||
|
SIFT 是一个由 SANS 公司提供的基于 Ubuntu 的取证发行版。它包含许多取证工具,如 Sleuth kit/Autopsy 。但 Sleuth kit/Autopsy 可以直接在 Ubuntu 或 Fedora 发行版本上直接安装,而不必下载 SIFT 的整个发行版本。
|
||||||
|
|
||||||
|
Sleuth Kit/Autopsy 是一个开源的电子取证调查工具,它可以用于从磁盘映像中恢复丢失的文件,以及为了特殊事件进行磁盘映像分析。 Autopsy 工具是 sleuth kit 的一个网页接口,支持 sleuth kit 的所有功能。这个工具在 Windows 和 Linux 平台下都可获取到。
|
||||||
|
|
||||||
|
### 安装 Sleuth kit ###
|
||||||
|
|
||||||
|
首先,从 [sleuthkit][1] 的网站下载 Sleuth kit 软件。使用下面的命令在虚拟终端下使用 wget 命令来下载它,下图展示了这个过程。
|
||||||
|
|
||||||
|
# wget http://cznic.dl.sourceforge.net/project/sleuthkit/sleuthkit/4.1.3/sleuthkit-4.1.3.tar.gz
|
||||||
|
|
||||||
|
![下载 Sleuth Kit](http://blog.linoxide.com/wp-content/uploads/2015/03/download-sleuthkeit.png)
|
||||||
|
|
||||||
|
使用下面的命令解压 sleuthkit-4.1.3.tar.gz 并进入解压后的目录:
|
||||||
|
|
||||||
|
# tar -xvzf sleuthkit-4.1.3.tar.gz
|
||||||
|
|
||||||
|
![解压过程](http://blog.linoxide.com/wp-content/uploads/2015/03/extract.png)
|
||||||
|
|
||||||
|
在安装 sleuth kit 之前,运行下面的命令来执行所需的检查:
|
||||||
|
|
||||||
|
#./configure
|
||||||
|
|
||||||
|
![configure](http://blog.linoxide.com/wp-content/uploads/2015/03/configure.png)
|
||||||
|
|
||||||
|
然后使用 Make 命令来编译 sleuth kit :
|
||||||
|
|
||||||
|
#make
|
||||||
|
|
||||||
|
![make](http://blog.linoxide.com/wp-content/uploads/2015/03/make.png)
|
||||||
|
|
||||||
|
最后,使用下面的命令将它安装到 **/usr/local** 目录下:
|
||||||
|
|
||||||
|
#make install
|
||||||
|
|
||||||
|
![make install](http://blog.linoxide.com/wp-content/uploads/2015/03/make-install.png)
|
||||||
|
|
||||||
|
### 安装 Autopsy 工具 ###
|
||||||
|
|
||||||
|
Sleuth kit 已经安装完毕,现在我们将为它安装 autopsy 界面。从 [sleuthkit 的 autopsy 页面][2]下载 Autopsy 软件。使用下面的命令在虚拟终端下使用 wget 命令来下载它,下图展示了这个过程。
|
||||||
|
|
||||||
|
# wget http://kaz.dl.sourceforge.net/project/autopsy/autopsy/2.24/autopsy-2.24.tar.gz
|
||||||
|
|
||||||
|
![Autpsy 的下载链接](http://blog.linoxide.com/wp-content/uploads/2015/03/autopsy.png)
|
||||||
|
|
||||||
|
使用下面的命令解压 autopsy-2.24.tar.gz 并进入解压后的目录:
|
||||||
|
|
||||||
|
# tar -xvzf autopsy-2.24.tar.gz
|
||||||
|
|
||||||
|
![Autopsy 的解压](http://blog.linoxide.com/wp-content/uploads/2015/03/Autopsy-extraction.png)
|
||||||
|
|
||||||
|
autopsy 的配置脚本将询问 NSRL (National Software Reference Library) 和 **Evidence_Locker** 文件夹的路径。
|
||||||
|
|
||||||
|
当弹窗问及 NSRL 时,输入 "n",并在 **/usr/local** 目录下创建名为 Evidence_Locker 的文件夹。Autopsy 将在 Evidence_Locker 文件夹下存储配置文件,审计记录和输出文件。
|
||||||
|
|
||||||
|
#mkdir /usr/local/Evidence_Locker
|
||||||
|
|
||||||
|
#cd autopsy-2.24
|
||||||
|
|
||||||
|
#./configure
|
||||||
|
|
||||||
|
![Autopsy 配置脚本](http://blog.linoxide.com/wp-content/uploads/2015/03/autopsy-configuration.png)
|
||||||
|
|
||||||
|
在安装过程中添加完 Evidence_Locker 的安装路径后, autopsy 在那里存储配置文件并展现如下的信息来运行 autopsy 程序。
|
||||||
|
|
||||||
|
![启动 Autopsy](http://blog.linoxide.com/wp-content/uploads/2015/03/start-autopsy.png)
|
||||||
|
|
||||||
|
在虚拟终端中键入 **./autopsy** 命令来启动 Sleuth kit 工具的图形界面:
|
||||||
|
|
||||||
|
![Autopsy](http://blog.linoxide.com/wp-content/uploads/2015/03/autopsy-started.png)
|
||||||
|
|
||||||
|
在浏览器中键入下面的地址来访问 autopsy 的界面:
|
||||||
|
|
||||||
|
http://localhost:9999/autopsy
|
||||||
|
|
||||||
|
下图展现了 autopsy 插件的主页面:
|
||||||
|
|
||||||
|
![主页](http://blog.linoxide.com/wp-content/uploads/2015/03/main-interface.png)
|
||||||
|
|
||||||
|
在 autopsy 工具中,点击 **新案例** 按钮来开始进行分析。键入案例名称,此次调查的描述和检查人的姓名,下图有具体的展示:
|
||||||
|
|
||||||
|
![创建新事件](http://blog.linoxide.com/wp-content/uploads/2015/03/create-new-case1.png)
|
||||||
|
|
||||||
|
在接下来的网页中,将展示在上一个的网页中键入的详细信息。接着点击 **增加主机** 按钮来添加有关要分析的机器的详细信息。
|
||||||
|
|
||||||
|
![增加主机](http://blog.linoxide.com/wp-content/uploads/2015/03/add-host1.png)
|
||||||
|
|
||||||
|
在下一个网页中键入主机名,相关的描述和要分析的机器的时区设置。
|
||||||
|
|
||||||
|
![添加主机的详细信息](http://blog.linoxide.com/wp-content/uploads/2015/03/add-host-detial.png)
|
||||||
|
|
||||||
|
添加主机后,点击 **增加映像** 按钮来为取证分析添加映像文件。
|
||||||
|
|
||||||
|
![添加映像](http://blog.linoxide.com/wp-content/uploads/2015/03/add-image.png)
|
||||||
|
|
||||||
|
在接下来的网页中点击 **增加映像文件** 按钮。它将打开一个新的网页,来询问映像文件的路径和选择映像的类型以及导入的方法。
|
||||||
|
|
||||||
|
![添加映像文件](http://blog.linoxide.com/wp-content/uploads/2015/03/Add-image-file.png)
|
||||||
|
|
||||||
|
正如下图中展示的那样,我们已经键入了 Linux 映像文件的路径。在我们这个例子中,映像文件类型是磁盘分区。
|
||||||
|
|
||||||
|
![添加映像分区](http://blog.linoxide.com/wp-content/uploads/2015/03/add-image-parition.png)
|
||||||
|
|
||||||
|
点击“下一步”按钮并在下一页中选择 **计算散列值** 的选项,这在下图中有展示。它也将检测所给映像的文件系统类型。
|
||||||
|
|
||||||
|
![映像和文件系统详情](http://blog.linoxide.com/wp-content/uploads/2015/03/image-and-file-system-detail.png)
|
||||||
|
|
||||||
|
下面的图片展示了静态分析之前映像文件的 MD5 散列值。
|
||||||
|
|
||||||
|
![散列值](http://blog.linoxide.com/wp-content/uploads/2015/03/hash1.png)
|
||||||
|
|
||||||
|
在下一个网页中, autopsy 展现了有关映像文件的如下信息:
|
||||||
|
|
||||||
|
- 映像的挂载点
|
||||||
|
- 映像的名称
|
||||||
|
- 所给映像的文件系统类型
|
||||||
|
|
||||||
|
点击 **详情** 按钮来获取更多有关所给映像文件的信息。它还提供了从映像文件的卷中导出未分配的片段和字符串的数据信息,这在下图中有展现。
|
||||||
|
|
||||||
|
![映像的详细信息](http://blog.linoxide.com/wp-content/uploads/2015/03/image-details.png)
|
||||||
|
|
||||||
|
在下图中那样,点击 **分析** 按钮来开始分析所给映像。它将开启另一个页面,其中包含了映像分析的多个选项。
|
||||||
|
|
||||||
|
![分析](http://blog.linoxide.com/wp-content/uploads/2015/03/analysis1.png)
|
||||||
|
|
||||||
|
在映像分析过程中,Autopsy 提供了如下的功能:
|
||||||
|
|
||||||
|
- 文件分析
|
||||||
|
- 关键字搜索
|
||||||
|
- 文件类型
|
||||||
|
- 映像详情
|
||||||
|
- 数据单元
|
||||||
|
|
||||||
|
下图展示的是在给定的 Linux 分区映像上进行文件分析:
|
||||||
|
|
||||||
|
![映像的分析](http://blog.linoxide.com/wp-content/uploads/2015/03/Analysis-of-image.png)
|
||||||
|
|
||||||
|
它将从所给映像中提取所有的文件和文件夹。在下图中也展示了已被删除的文件的提取:
|
||||||
|
|
||||||
|
![已被删除的文件](http://blog.linoxide.com/wp-content/uploads/2015/03/deleted.png)
|
||||||
|
|
||||||
|
### 结论 ###
|
||||||
|
|
||||||
|
希望这篇文章能够给那些进入磁盘映像静态分析领域的新手提供帮助。Autopsy 是 sleuth kit 的网页界面,提供了在 Windows 和 Linux 磁盘映像中进行诸如字符串提取,恢复被删文件,时间线分析,网络浏览历史,关键字搜索和邮件分析等功能。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://linoxide.com/ubuntu-how-to/autopsy-sleuth-kit-installation-ubuntu/
|
||||||
|
|
||||||
|
作者:[nido][a]
|
||||||
|
译者:[FSSlc](https://github.com/FSSlc)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://linoxide.com/author/naveeda/
|
||||||
|
[1]:http://www.sleuthkit.org/sleuthkit/download.php
|
||||||
|
[2]:http://www.sleuthkit.org/autopsy/download.php
|
@ -16,7 +16,7 @@
|
|||||||
|
|
||||||
$ cat .ssh/id_rsa.pub | ssh aliceB@hostB 'cat >> .ssh/authorized_keys'
|
$ cat .ssh/id_rsa.pub | ssh aliceB@hostB 'cat >> .ssh/authorized_keys'
|
||||||
|
|
||||||
自此以后,从aliceA@hostA上ssh到aliceB@hostB上再也不需要输入密码。
|
自此以后,从aliceA@hostA上ssh到aliceB@hostB上再也不需要输入密码。(LCTT 译注:上述的创建目录并复制的操作也可以通过一个 ssh-copy-id 命令一步完成:`ssh-copy-id -i ~/.ssh/id_rsa.pub aliceB@hostB`)
|
||||||
|
|
||||||
### 疑难解答 ###
|
### 疑难解答 ###
|
||||||
|
|
||||||
@ -34,7 +34,7 @@ via: http://xmodulo.com/how-to-enable-ssh-login-without.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[KayGuoWhu](https://github.com/KayGuoWhu)
|
译者:[KayGuoWhu](https://github.com/KayGuoWhu)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
Linux有问必答-- 如何在VPS上安装和访问CentOS远程桌面
|
Linux有问必答:如何在VPS上安装和访问CentOS 7远程桌面
|
||||||
================================================================================
|
================================================================================
|
||||||
> **提问**: 我想在VPS中安装CentOS桌面,并可以直接从我家远程访问GUI桌面。有什么建议可以在VPS上设置和访问CentOS远程桌面?
|
> **提问**: 我想在VPS中安装CentOS桌面,并可以直接从我家远程访问GUI桌面。在VPS上设置和访问CentOS远程桌面有什么建议吗?
|
||||||
|
|
||||||
如何远程办公或者远程弹性化工作制在技术领域正变得越来越流行。这个趋势背后的一个技术就是远程桌面。你的桌面环境在云中,你可以在任何你去的地方,或者在家或者工作场所访问你的远程桌面。
|
如何远程办公或者远程弹性化工作制在技术领域正变得越来越流行。这个趋势背后的一个技术就是远程桌面。你的桌面环境在云中,你可以在任何你去的地方,或者在家或者工作场所访问你的远程桌面。
|
||||||
|
|
||||||
@ -10,7 +10,7 @@ Linux有问必答-- 如何在VPS上安装和访问CentOS远程桌面
|
|||||||
|
|
||||||
### 第一步: 安装CentOS桌面 ###
|
### 第一步: 安装CentOS桌面 ###
|
||||||
|
|
||||||
如果现在的CentOS版本是没有桌面的最小版本,你需要先在VPS上安装桌面(比如GNOME)。比如,DigitalOcean的镜像就是最小版本,它需要如下安装[桌面GUI][2]
|
如果你现在安装的CentOS版本是没有桌面的最小版本,你需要先在VPS上安装桌面(比如GNOME)。比如,DigitalOcean的镜像就是最小版本,它需要如下安装[桌面GUI][2]
|
||||||
|
|
||||||
# yum groupinstall "GNOME Desktop"
|
# yum groupinstall "GNOME Desktop"
|
||||||
|
|
||||||
@ -36,15 +36,15 @@ CentOS依靠systemd来管理和配置系统服务。所以我们将使用systemd
|
|||||||
# systemctl status vncserver@:.service
|
# systemctl status vncserver@:.service
|
||||||
# systemctl is-enabled vncserver@.service
|
# systemctl is-enabled vncserver@.service
|
||||||
|
|
||||||
默认上,刚安装的VNC服务并没有激活(禁用)。
|
默认的,刚安装的VNC服务并没有激活(禁用)。
|
||||||
|
|
||||||
![](https://farm8.staticflickr.com/7613/16877514732_8ccffe7b6b_b.jpg)
|
![](https://farm8.staticflickr.com/7613/16877514732_8ccffe7b6b_b.jpg)
|
||||||
|
|
||||||
现在服务一份通用的VNC服务文件来位用户xmodulo创建一个VNC服务配置。
|
现在复制一份通用的VNC服务文件来为用户xmodulo创建一个VNC服务配置。
|
||||||
|
|
||||||
# cp /lib/systemd/system/vncserver@.service /etc/systemd/system/vncserver@:1.service
|
# cp /lib/systemd/system/vncserver@.service /etc/systemd/system/vncserver@:1.service
|
||||||
|
|
||||||
用本文编辑器来打开配置文件,用实际的用户名(比如:xmodulo)来替换[Service]下面的<USER>。同样。在ExecStart后面追加 "-geometry <resolution>" 参数。最后,要修改下面两行加粗字体的两行。
|
用本文编辑器来打开配置文件,用实际的用户名(比如:xmodulo)来替换[Service]下面的<USER>。同样。在ExecStart后面追加 "-geometry <resolution>" 参数。最后,要修改下面“ExecStart”和“PIDFile”两行。
|
||||||
|
|
||||||
# vi /etc/systemd/system/vncserver@:1.service
|
# vi /etc/systemd/system/vncserver@:1.service
|
||||||
|
|
||||||
@ -85,7 +85,7 @@ CentOS依靠systemd来管理和配置系统服务。所以我们将使用systemd
|
|||||||
|
|
||||||
### 第三步:通过SSH连接到远程桌面 ###
|
### 第三步:通过SSH连接到远程桌面 ###
|
||||||
|
|
||||||
设计上,VNC使用的远程帧缓存(RFB)并不是一种安全的协议。那么在VNC客户端上直接连接到VNC服务器上并不是一个好主意。任何敏感信息比如密码都可以在VNC流量中被轻易地泄露。因此,我强烈建议使用SSH隧道来[加密你的VNC流量][3]。
|
从设计上说,VNC使用的远程帧缓存(RFB)并不是一种安全的协议,那么在VNC客户端上直接连接到VNC服务器上并不是一个好主意。任何敏感信息比如密码都可以在VNC流量中被轻易地泄露。因此,我强烈建议使用SSH隧道来[加密你的VNC流量][3]。
|
||||||
|
|
||||||
在你要运行VNC客户端的本机上,使用下面的命令来创建一个连接到远程VPS的SSH通道。当被要输入SSH密码时,输入用户的密码。
|
在你要运行VNC客户端的本机上,使用下面的命令来创建一个连接到远程VPS的SSH通道。当被要输入SSH密码时,输入用户的密码。
|
||||||
|
|
||||||
@ -99,7 +99,7 @@ CentOS依靠systemd来管理和配置系统服务。所以我们将使用systemd
|
|||||||
|
|
||||||
![](https://farm8.staticflickr.com/7639/16691289910_fae83510fb_o.png)
|
![](https://farm8.staticflickr.com/7639/16691289910_fae83510fb_o.png)
|
||||||
|
|
||||||
你将被要求输入VNC密码。当你输入VNC密码时,你就可以安全地连接到CentOS的远程桌面了.
|
你将被要求输入VNC密码。当你输入VNC密码时,你就可以安全地连接到CentOS的远程桌面了。
|
||||||
|
|
||||||
![](https://farm8.staticflickr.com/7614/16877678411_aa8349f6b1_c.jpg)
|
![](https://farm8.staticflickr.com/7614/16877678411_aa8349f6b1_c.jpg)
|
||||||
|
|
||||||
@ -111,7 +111,7 @@ via: http://ask.xmodulo.com/centos-remote-desktop-vps.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[geekpi](https://github.com/geekpi)
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,55 @@
|
|||||||
|
更漂亮的 Square 2.0图标包
|
||||||
|
================================================================================
|
||||||
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Square_Icon_Pack_Linux_3.jpeg)
|
||||||
|
|
||||||
|
优雅、现代的[Square图标主题][1]最近更新到了2.0版,它比以前更漂亮了。Square图标包与其他主要的桌面环境如**Unity、 GNOME、KDE、 MATE等等**兼容。这意味着你可以在所有的流行Linux发行版如Ubuntu、Fedora、Linux Mint、elementary OS等等中使用它。 这个图标包估计包含超过了15000个图标。
|
||||||
|
|
||||||
|
### 在Linux中安装Square 2.0图标包 ###
|
||||||
|
|
||||||
|
有两种不同的Square图标,暗色和亮色。基于你的喜好,你可以选择二者之一。出于体验的目的,我建议你两个主题包都下载。
|
||||||
|
|
||||||
|
你可以用下面的链接下载图标包。文件存储在Google Drive,因此如果你没有看见像[SourceForge][2]这样标准的下载网站时不要怀疑。
|
||||||
|
|
||||||
|
- [Square Dark Icons][3]
|
||||||
|
- [Square Light Icons][4]
|
||||||
|
|
||||||
|
要使用图标主题,解压下载的文件到~/.icons文件夹下。如果它不存在,就创建它。当这些文件放好后,基于你的桌面环境,使用一个工具来改变图标主题。我以前写了一些关于这个主题的教程。如果你需要额外的帮助,那么欢迎指出来:
|
||||||
|
|
||||||
|
- [如何在Ubuntu Unity中改变主题][5]
|
||||||
|
- [如何在GNOME Shell中改变主题][6]
|
||||||
|
- [如何在Linux Mint中改变主题][7]
|
||||||
|
- [如何在Elementary OS Freya中改变主题][8]
|
||||||
|
|
||||||
|
### 试一下 ###
|
||||||
|
|
||||||
|
这是我用Square图标在Ubuntu 14.04中的效果。我背景使用的是[Ubuntu 15.04 默认壁纸][9]。
|
||||||
|
|
||||||
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Square_Icon_Pack_Linux_2.jpeg)
|
||||||
|
|
||||||
|
Square主题中几个图标的样子:
|
||||||
|
|
||||||
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/03/Square_Icon_Pack_Linux.jpeg)
|
||||||
|
|
||||||
|
你觉得怎么样?你认为它是[Ubuntu 14.04中最佳的图标主题][10]之一么?你会分享它并期待更多关于自定义Linux桌面的文章么?
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://itsfoss.com/square-2-0-icon-pack-linux/
|
||||||
|
|
||||||
|
作者:[Abhishek][a]
|
||||||
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://itsfoss.com/author/abhishek/
|
||||||
|
[1]:http://gnome-look.org/content/show.php/Square?content=163513
|
||||||
|
[2]:http://sourceforge.net/
|
||||||
|
[3]:http://gnome-look.org/content/download.php?content=163513&id=1&tan=62806435
|
||||||
|
[4]:http://gnome-look.org/content/download.php?content=163513&id=2&tan=19789941
|
||||||
|
[5]:http://itsfoss.com/how-to-install-themes-in-ubuntu-13-10/
|
||||||
|
[6]:http://itsfoss.com/install-switch-themes-gnome-shell/
|
||||||
|
[7]:http://itsfoss.com/install-icon-linux-mint/
|
||||||
|
[8]:http://itsfoss.com/install-themes-icons-elementary-os-freya/
|
||||||
|
[9]:http://itsfoss.com/default-wallpapers-ubuntu-1504/
|
||||||
|
[10]:http://itsfoss.com/best-icon-themes-ubuntu-1404/
|
@ -1,12 +1,13 @@
|
|||||||
# Linux 下四种安全删除文件的工具 #
|
Linux 下四种安全删除文件的工具
|
||||||
|
===============
|
||||||
|
|
||||||
任何一个普通水平的计算机用户都知道,从计算机系统中删除的任意数据都可以稍候通过一些努力恢复出来。当你不小心删除了你的重要数据,这是一个不错的方案。但是大多数情况,你不希望你的隐私数据被轻易地恢复。不论何时,我们删除任意的文件,操作系统删除的仅仅是特定数据的索引。这就意味着,数据仍然保存在磁盘的某块地方,这种方法是不安全的,任何一个聪明的计算机黑客可以使用任意不错的数据恢复工具来恢复你删除的数据。Linux 用户利用我们都知晓的 "rm" 命令来从他们的操作系统中删除数据,但是 "rm" 命令在约定俗成的场景下工作。从这个命令删除的数据也可以使用特殊的文件恢复工具恢复。
|
任何一个普通水平的计算机用户都知道,从计算机系统中删除的任意数据都可以稍后通过一些努力恢复出来。当你不小心删除了你的重要数据时,这是一个不错的方案。但是大多数情况,你不希望你的隐私数据被轻易地恢复。不论何时,我们删除的任意文件,操作系统删除的仅仅是对特定数据的索引。这就意味着,数据仍然保存在磁盘的某块地方,这种方法是不安全的,任何一个聪明的计算机黑客可以使用各种不错的数据恢复工具来恢复你删除的数据。Linux 用户利用我们都知晓的 "rm" 命令来从他们的操作系统中删除数据,但是 "rm" 命令也是像上面说的那样删除文件。从这个命令删除的数据也可以使用特殊的文件恢复工具恢复。
|
||||||
|
|
||||||
让我们看看怎样安全并且完整地从你地 Linux 系统中删除文件或者文件夹。以下提到的工具可以完全地删除数据,因此那些恢复工具很难找到真实数据的痕迹然后恢复它。
|
让我们看看怎样安全并完整地从你的 Linux 系统中删除文件或者文件夹。以下提到的工具可以完全地删除数据,因此那些恢复工具很难找到真实数据的痕迹然后恢复它。
|
||||||
|
|
||||||
### Secure-Delete ###
|
### Secure-Delete ###
|
||||||
|
|
||||||
Secure-Delete 是一组为 Linux 操作系统而生的工具集合,他们为永久删除文件提供高级的技术支持。一旦 Secure-Delete 安装在任意的 Linux 系统,它会提供如下的四个命令:
|
Secure-Delete 是一组为 Linux 操作系统而生的工具集合,他们为永久删除文件提供了先进的技术支持。一旦 Secure-Delete 安装在各种 Linux 系统上,就提供了如下的四个命令:
|
||||||
|
|
||||||
- srm
|
- srm
|
||||||
- smem
|
- smem
|
||||||
@ -45,13 +46,13 @@ Secure-Delete 是一组为 Linux 操作系统而生的工具集合,他们为
|
|||||||
|
|
||||||
sudo sswap /dev/sda5
|
sudo sswap /dev/sda5
|
||||||
|
|
||||||
“**smem**” 用来清理在内存中的内容,它保证当系统重启或者关机时随机存取存储器(RAM)中的内容被清理,但是残余的数据痕迹仍然保存在内存。这个命令提供安全的内存清理,简单地在终端中运行 smem 命令。
|
“**smem**” 用来清理在内存中的内容,虽然当系统重启或者关机时会清理随机存取存储器(RAM)中的内容,但是内存中仍然会保留一些数据的残留痕迹。这个命令提供安全的内存清理,简单地在终端中运行 smem 命令即可。
|
||||||
|
|
||||||
smem
|
smem
|
||||||
|
|
||||||
### Shred ###
|
### Shred ###
|
||||||
|
|
||||||
"shred" 命令销毁文件或者文件夹的内容,在某种程度上,不可能恢复。它使用随机生成的数据模式来持续重写文件,因此很难恢复任意的被销毁的数据,即使是那些黑客或者窃贼使用高水平的数据恢复工具或者设备。Shred 在 Linux 发行版中时默认安装的,如果你想,你可以运行如下命令来找到它的安装目录:
|
"shred" 命令以一种不可恢复的方式来销毁文件或者文件夹的内容。它使用随机生成的数据模式来持续覆写文件,因此很难恢复任意的被销毁的数据,即使是那些黑客或者窃贼使用高水平的数据恢复工具或者设备。Shred 默认安装在所有 Linux 发行版中,如果你想,你可以运行如下命令来找到它的安装目录:
|
||||||
|
|
||||||
aun@eagle:~$ whereis shred
|
aun@eagle:~$ whereis shred
|
||||||
|
|
||||||
@ -75,17 +76,17 @@ Shred 默认情况下使用随机内容重写数据 25 次。如果你想它重
|
|||||||
|
|
||||||
### dd ###
|
### dd ###
|
||||||
|
|
||||||
这个命令起初是用于磁盘克隆的。它用于一个分区或者一个磁盘复制到另一个分区或者磁盘。但是它还用于安全地清除硬盘或者分区的内容。运行如下命令使用随机数据来重写你的当前数据。你不需要安装 dd 命令,所有的 Linux 分发版都已经包含了此命令。
|
这个命令起初是用于磁盘克隆的。它用于将一个分区或者一个磁盘复制到另一个分区或者磁盘。但是它还可用于安全地清除硬盘或者分区的内容。运行如下命令使用随机数据来重写你的当前数据。你不需要安装 dd 命令,所有的 Linux 分发版都已经包含了此命令。
|
||||||
|
|
||||||
sudo dd if=/dev/random of=/dev/sda
|
sudo dd if=/dev/random of=/dev/sda
|
||||||
|
|
||||||
你也可以重写磁盘或者分区中的内容,只需要简单地将所有替换为 “zero”。
|
你也可以覆写磁盘或者分区中的内容,只需要简单地将所有替换为 “zero”。
|
||||||
|
|
||||||
sudo dd if=/dev/zero of=/dev/sda
|
sudo dd if=/dev/zero of=/dev/sda
|
||||||
|
|
||||||
### Wipe ###
|
### Wipe ###
|
||||||
|
|
||||||
Wipe 起初开发的目的是从磁媒体中安全地擦除文件。这个命令行工具使用特殊的模式来重复地写文件。它使用 fsync() 调用和或 O_SYNC 位来强制访问磁盘,并且使用 Gutmann 算法来重复地写。你可以使用此命令删除单个文件,文件夹或者整个磁盘的内容,但是使用 wipe 命令来删除整个磁盘的模式会耗费大量的时间。另外,安装和使用这个工具相当容易。
|
Wipe 起初开发的目的是从磁性介质中安全地擦除文件。这个命令行工具使用特殊的模式来重复地写文件。它使用 fsync() 调用和/或 O_SYNC 位来强制访问磁盘,并且使用 Gutmann 算法来重复地写。你可以使用此命令删除单个文件、文件夹或者整个磁盘的内容,但是使用 wipe 命令来删除整个磁盘的模式会耗费大量的时间。另外,安装和使用这个工具相当容易。
|
||||||
|
|
||||||
在 ubuntu 的终端中运行如下命令来安装 wipe。
|
在 ubuntu 的终端中运行如下命令来安装 wipe。
|
||||||
|
|
||||||
@ -123,7 +124,7 @@ via: http://linoxide.com/security/delete-files-permanatly-linux/
|
|||||||
|
|
||||||
作者:[Aun Raza][a]
|
作者:[Aun Raza][a]
|
||||||
译者:[dbarobin](https://github.com/dbarobin)
|
译者:[dbarobin](https://github.com/dbarobin)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,163 @@
|
|||||||
|
Linux用户应知应会的7个‘ls’命令的独特技巧
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
在前面我们系列报道的两篇文章中,我们已经涵盖了关于‘ls’命令的绝大多数内容。本文时‘ls命令’系列的最后一部分。如果你还没有读过该系列的其它两篇文章,你可以访问下面的链接。
|
||||||
|
|
||||||
|
- [Linux中的15个基本‘ls’命令示例][1]
|
||||||
|
- [15 个‘ls’命令的面试问题(一)][2]
|
||||||
|
- [10 个‘ls’命令面试的问题(二)][3]
|
||||||
|
|
||||||
|
![7 Quirky ls Command Tricks](http://www.tecmint.com/wp-content/uploads/2015/03/ls-command-tricks.jpg)
|
||||||
|
|
||||||
|
*7个ls命令独特技巧*
|
||||||
|
|
||||||
|
### 1. 以各种时间格式附带时间戳列出目录中的内容 ###
|
||||||
|
|
||||||
|
要以时间格式列出目录内容,我们需要选择以下两种方法中的任何一种。
|
||||||
|
|
||||||
|
# ls -l –time-style=[STYLE] (方法 A)
|
||||||
|
|
||||||
|
**注意** - 上面的开关`--time`的格式必须和`-l`开关同时使用,否则达不到目的。
|
||||||
|
|
||||||
|
# ls -full-time (方法 B)
|
||||||
|
|
||||||
|
可以用以下任何一个选项替换`[STYLE]`。
|
||||||
|
|
||||||
|
full-iso
|
||||||
|
long-iso
|
||||||
|
iso
|
||||||
|
locale
|
||||||
|
+%H:%M:%S:%D
|
||||||
|
|
||||||
|
**注意** - 在上面行中,H(时),M(分),S(秒),D(日)的顺序可以任意调整。此外,你只需选择那些相关的选项,而不是所有选项。例如,`ls -l --time-style=+%H`将只显示小时。`ls -l --time-style=+%H:%M:%D`将显示小时、分钟和日。
|
||||||
|
|
||||||
|
# ls -l --time-style=full-iso
|
||||||
|
|
||||||
|
![ls Command Full Time Style](http://www.tecmint.com/wp-content/uploads/2015/03/ls-Command-Full-Time-Style.gif)
|
||||||
|
|
||||||
|
*ls命令的完整 ISO时间格式*
|
||||||
|
|
||||||
|
# ls -l --time-style=long-iso
|
||||||
|
|
||||||
|
![Long Time Style Listing](http://www.tecmint.com/wp-content/uploads/2015/03/Long-Time-Listing-Format.gif)
|
||||||
|
|
||||||
|
*长时间格式列表*
|
||||||
|
|
||||||
|
# ls -l --time-style=iso
|
||||||
|
|
||||||
|
![Time Style Listing](http://www.tecmint.com/wp-content/uploads/2015/03/Local-Time-Style-Listing.gif)
|
||||||
|
|
||||||
|
*时间格式列表*
|
||||||
|
|
||||||
|
# ls -l --time-style=locale
|
||||||
|
|
||||||
|
![Locale Time Style Listing](http://www.tecmint.com/wp-content/uploads/2015/03/Hour-Mintue-Time-Style-Listing.gif)
|
||||||
|
|
||||||
|
*本地时间格式列表*
|
||||||
|
|
||||||
|
# ls -l --time-style=+%H:%M:%S:%D
|
||||||
|
|
||||||
|
![Date and Time Style Listing](http://www.tecmint.com/wp-content/uploads/2015/03/Full-Time-Style-Listing.gif)
|
||||||
|
|
||||||
|
*日期和时间格式列表*
|
||||||
|
|
||||||
|
# ls --full-time
|
||||||
|
|
||||||
|
![Full Style Time Listing](http://www.tecmint.com/wp-content/uploads/2015/03/Full-Style-Time-Listing.gif)
|
||||||
|
|
||||||
|
*完整格式时间列表*
|
||||||
|
|
||||||
|
### 2. 以多种格式列出目录内容,如以逗号分隔、水平格式、长格式、垂直格式、交叉格式等列出。 ###
|
||||||
|
|
||||||
|
目录内容可以用以下建议的ls命令各种格式列出:
|
||||||
|
|
||||||
|
# ls --format=across # 交叉
|
||||||
|
# ls --format=comma # 逗号
|
||||||
|
# ls --format=horizontal # 水平
|
||||||
|
# ls --format=long # 长格式
|
||||||
|
# ls --format=single-column # 单栏
|
||||||
|
# ls --format=verbose # 详情
|
||||||
|
# ls --format=vertical # 垂直
|
||||||
|
|
||||||
|
![Listing Formats of ls Command](http://www.tecmint.com/wp-content/uploads/2015/03/ls-command-Listing-Formats.gif)
|
||||||
|
|
||||||
|
*ls命令的列出格式*
|
||||||
|
|
||||||
|
### 3. 使用ls命令为目录内容输出结果添加像(/=@|)这样的指示符。 ###
|
||||||
|
|
||||||
|
带有`-p`选项的ls命令将实现该目的。它会根据文件类型添加上面这些指示符其中之一。
|
||||||
|
|
||||||
|
# ls -p
|
||||||
|
|
||||||
|
![Append Indicators to Content](http://www.tecmint.com/wp-content/uploads/2015/03/Append-Indicators.gif)
|
||||||
|
|
||||||
|
*添加指示符到内容*
|
||||||
|
|
||||||
|
### 4. 根据扩展名、大小、时间和版本对目录内容排序。 ###
|
||||||
|
|
||||||
|
我们可以使用`--extension`选项来按照扩展名对输出结果排序,`--size`扩展选项按照大小排序,`-t`扩展选项按照时间排序,`-v`扩展选项对版本排序。
|
||||||
|
|
||||||
|
我们也可以使用`--none`选项,它会以常规方式输出结果而不会进行排序。
|
||||||
|
|
||||||
|
# ls --sort=extension
|
||||||
|
# ls --sort=size
|
||||||
|
# ls --sort=time
|
||||||
|
# ls --sort=version
|
||||||
|
# ls --sort=none
|
||||||
|
|
||||||
|
![Sort Listing of Content by Options](http://www.tecmint.com/wp-content/uploads/2015/03/Sort-Content-by-Extensions.gif)
|
||||||
|
|
||||||
|
*通过选项对内容排序列出*
|
||||||
|
|
||||||
|
### 5. 使用ls命令打印目录中各个项的数字UID和GID。 ###
|
||||||
|
|
||||||
|
上面的环境可以通过使用带有-n标识的ls命令来实现。
|
||||||
|
|
||||||
|
# ls -n
|
||||||
|
|
||||||
|
![Print Listing of Content by UID and GID](http://www.tecmint.com/wp-content/uploads/2015/03/Print-UID-GID-of-Contents.gif)
|
||||||
|
|
||||||
|
*通过UID和GID对打印内容列表*
|
||||||
|
|
||||||
|
### 6. 标准输出结果中打印目录内容中比默认指定的更多栏目。 ###
|
||||||
|
|
||||||
|
好吧,ls命令根据屏幕大小自动输出目录内容。
|
||||||
|
|
||||||
|
然而,我们可以手动分配屏幕宽度的值和出现的栏目的控制数。这可以通过使用‘`--width`’开关实现。
|
||||||
|
|
||||||
|
# ls --width 80
|
||||||
|
# ls --width 100
|
||||||
|
# ls --width 150
|
||||||
|
|
||||||
|
![List Content Based on Window Sizes](http://www.tecmint.com/wp-content/uploads/2015/03/List-Content-By-More-Column.gif)
|
||||||
|
|
||||||
|
*根据窗口大小列出内容*
|
||||||
|
|
||||||
|
**注意**: 你可以试验你可以给width标识传递什么值。
|
||||||
|
|
||||||
|
### 7. 通过ls命令为列出的目录内容手动指定的制表符大小而不是默认的8。 ###
|
||||||
|
|
||||||
|
# ls --tabsize=[value]
|
||||||
|
|
||||||
|
![List Content by Table Size](http://www.tecmint.com/wp-content/uploads/2015/03/List-Content-by-Table-Size.gif)
|
||||||
|
|
||||||
|
*按表尺寸列出内容*
|
||||||
|
|
||||||
|
**注意**: 指定`[Value]`的数值。
|
||||||
|
|
||||||
|
到目前为止,都讲完了。保持连线,我们会推出下一篇文章。别忘了在下面的评论中为我们提供有价值的反馈。为我们点赞并分享,帮我们推广。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.tecmint.com/linux-ls-command-tricks/
|
||||||
|
|
||||||
|
作者:[Avishek Kumar][a]
|
||||||
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.tecmint.com/author/avishek/
|
||||||
|
[1]:https://linux.cn/article-5109-1.html
|
||||||
|
[2]:https://linux.cn/article-5349-1.html
|
||||||
|
[3]:https://linux.cn/article-5350-1.html
|
@ -1,10 +1,11 @@
|
|||||||
怎样在Github上做开源代码库的主人
|
怎样在Github上托管开源代码库
|
||||||
================================================================================
|
================================================================================
|
||||||
大家好,今天我们要学习一下怎样管理github.com库中的开源软件源代码。GitHub是一个基于web的Git库托管服务,提供分布式修改控制和Git的源代码管理(SCM)功能并加入了自身的特点。它给开源和私有项目提供了一个互相协作的工作区、代码预览和代码管理功能。不像Git,一个完完全全的命令行工具,GitHub提供了一个基于web的图形化界面和桌面,也整合了手机。GitHub同时提供了私有库付费计划和免费账号,都是用来管理开源软件项目的。
|
|
||||||
|
大家好,今天我们要学习一下怎样在github.com提供的仓库中托管开源软件源代码。GitHub是一个基于web的Git仓库托管服务,提供基于 git 的分布式版本控制和源代码管理(SCM)功能,并加入了自身的特点。它给开源项目和私有项目提供了一个互相协作的工作区、代码预览和代码管理功能。不像Git是一个完完全全的命令行工具,GitHub提供了一个基于web的图形化界面和桌面,也整合了手机操作。GitHub同时提供了私有库付费计划和通常用来管理开源软件项目的免费账号。
|
||||||
|
|
||||||
![github universe logo](http://blog.linoxide.com/wp-content/uploads/2015/03/github-universe.jpg)
|
![github universe logo](http://blog.linoxide.com/wp-content/uploads/2015/03/github-universe.jpg)
|
||||||
|
|
||||||
这是一种快速灵活,基于web的托管服务,它使用方便,管理分布式修改控制系统也是相当容易,任何人都能为了将它们使用、贡献、共享、问题跟踪和更多的全球各地数以百万计的人在github的库里管理他们的软件源代码。这里有一些简单快速地管理软件源代码的方法。
|
这是一种快速灵活,基于web的托管服务,它使用方便,管理分布式版本控制系统也是相当容易,任何人都能将他们的软件源代码托管到 github,让全球各地数以百万计的人可以使用它、参与贡献、共享它、进行问题跟踪以及更多的用途。这里有一些简单快速地托管软件源代码的方法。
|
||||||
|
|
||||||
### 1. 创建一个新的Github账号 ###
|
### 1. 创建一个新的Github账号 ###
|
||||||
|
|
||||||
@ -20,7 +21,7 @@
|
|||||||
|
|
||||||
### 2. 创建一个新的库 ###
|
### 2. 创建一个新的库 ###
|
||||||
|
|
||||||
成功注册新账号或登录上Github之后,我们需要创建一个新的库来开始我们的正题。
|
成功注册新账号或登录上Github之后,我们需要创建一个新的库来开始我们的征程。
|
||||||
|
|
||||||
点击位于顶部靠右账号id旁边的**(+)**按钮,然后点击“New Repository”。
|
点击位于顶部靠右账号id旁边的**(+)**按钮,然后点击“New Repository”。
|
||||||
|
|
||||||
@ -46,13 +47,13 @@
|
|||||||
|
|
||||||
现在git已经准备就绪,我们要上传代码了。
|
现在git已经准备就绪,我们要上传代码了。
|
||||||
|
|
||||||
**注意**:为了避免错误,不要用**README**文件、许可证或gitignore文件来初始化新库,你可以在项目推送到Github上之后再添加它们。
|
**注意**:为了避免错误,不要在初始化的新库中包含**README**、license或gitignore等文件,你可以在项目推送到Github上之后再添加它们。
|
||||||
|
|
||||||
在终端上,我们需要把当前工作目录更改为你的本地项目,然后将本地目录初始化为Git库。
|
在终端上,我们需要切换当前工作目录为你的本地项目的目录,然后将其初始化为Git库。
|
||||||
|
|
||||||
$ git init
|
$ git init
|
||||||
|
|
||||||
接着我们在我们的新的本地库里添加的文件来作为我们的首次提交内容。
|
接着我们添加新的本地库里中的文件,作为我们的首次提交内容。
|
||||||
|
|
||||||
$ git add .
|
$ git add .
|
||||||
|
|
||||||
@ -62,16 +63,16 @@
|
|||||||
|
|
||||||
![git commit](http://blog.linoxide.com/wp-content/uploads/2015/03/git-commit.png)
|
![git commit](http://blog.linoxide.com/wp-content/uploads/2015/03/git-commit.png)
|
||||||
|
|
||||||
在终端上,我们要给远程库添加URL地址,用于以后我们能提交我们本地的库。
|
在终端上,添加远程库的URL地址,以便我们的本地库推送到远程。
|
||||||
|
|
||||||
$ git remote add origin remote Repository url
|
$ git remote add origin 远程库的URL
|
||||||
$ git remote -v
|
$ git remote -v
|
||||||
|
|
||||||
![adding remote url](http://blog.linoxide.com/wp-content/uploads/2015/03/adding-remote-url.png)
|
![adding remote url](http://blog.linoxide.com/wp-content/uploads/2015/03/adding-remote-url.png)
|
||||||
|
|
||||||
注意:请确保将远程库的URL替换成了自己的远程库的URL。
|
注意:请确保将上述“远程库的URL”替换成了你自己的远程库的URL。
|
||||||
|
|
||||||
现在,要将我们的本地库提交至GitHub版本库中,我们需要运行一下命令并且输入所需的用户名和密码。
|
现在,要将我们的本地库的改变推送至GitHub的版本库中,我们需要运行以下命令,并且输入所需的用户名和密码。
|
||||||
|
|
||||||
$ git push origin master
|
$ git push origin master
|
||||||
|
|
||||||
@ -87,9 +88,9 @@
|
|||||||
|
|
||||||
请把以上这条URL地址更改成你想要克隆的地址。
|
请把以上这条URL地址更改成你想要克隆的地址。
|
||||||
|
|
||||||
### 更新改动 ###
|
### 推送改动 ###
|
||||||
|
|
||||||
如果我们对我们的代码做了更改并想把它们提交至我们的远程库中,我们应该在该目录下运行以下命令。
|
如果我们对我们的代码做了更改并想把它们推送至我们的远程库中,我们应该在该目录下运行以下命令。
|
||||||
|
|
||||||
$ git add .
|
$ git add .
|
||||||
$ git commit -m "Updating"
|
$ git commit -m "Updating"
|
||||||
@ -97,7 +98,7 @@
|
|||||||
|
|
||||||
### 结论 ###
|
### 结论 ###
|
||||||
|
|
||||||
啊哈!我们已经成功地管理我们在Github库中的项目源代码了。快速灵活的Github基于web的托管服务,分布式修改控制系统使用起来方便容易。数百万个非常棒的开源项目驻扎在github上。所以,如果你有任何问题、建议或反馈,请在评论中告诉我们。谢谢大家!好好享受吧 :-)
|
啊哈!我们已经成功地将我们的项目源代码托管到Github的库中了。Github是快速灵活的基于web的托管服务,分布式版本控制系统使用起来方便容易。数百万个非常棒的开源项目驻扎在github上。所以,如果你有任何问题、建议或反馈,请在评论中告诉我们。谢谢大家!好好享受吧 :-)
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -105,7 +106,7 @@ via: http://linoxide.com/usr-mgmt/host-open-source-code-repository-github/
|
|||||||
|
|
||||||
作者:[Arun Pyasi][a]
|
作者:[Arun Pyasi][a]
|
||||||
译者:[ZTinoZ](https://github.com/ZTinoZ)
|
译者:[ZTinoZ](https://github.com/ZTinoZ)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,100 @@
|
|||||||
|
如何交互式地创建一个Docker容器
|
||||||
|
===============================================================================
|
||||||
|
|
||||||
|
大家好,今天我们来学习如何使用一个docker镜像交互式地创建一个Docker容器。当我们从镜像中启动一个Docker进程,Docker就会获取该镜像及其父镜像,并重复这个过程,直到到达基础镜像。然后联合文件系统(UFS)会在其顶层添加一个读写层。读写层被称之为容器,它包含了一些关于父镜像信息及一些其他的信息,如唯一ID,网络配置和资源限制等。容器是有状态的,其状态可以从 **运行态** 切换到 **退出态**。一个处于 **运行态**的容器包含了在CPU上面运行的进程树,于其它在该主机上运行的进程相隔离,而**退出态**是指文件系统的状态,并保留了其退出值。你可以使用它来启动,停止和重启一个容器。
|
||||||
|
|
||||||
|
Docker技术为IT界带来了巨大的改变,它使得云服务可以用来共享应用和工作流程自动化,使得应用可以用组件快速组合,消除了开发、品质保证、产品环境间的摩擦。在这篇文章中,我们将会建立CentOS环境,然后用Apache网络服务器提供一个网站服务。
|
||||||
|
|
||||||
|
这是一个快速且容易的教程,讨论我们怎样使用交互的shell,以交互的方式来创建一个容器。
|
||||||
|
|
||||||
|
### 1. 运行一个Docker实例 ###
|
||||||
|
|
||||||
|
Docker首先会尝试从本地取得并运行所需的镜像,如果在本地主机上没有发现,它就会从[Docker公共注册中心][1]拉取。这里,我们将会拉取镜像并在 Docker 容器中创建一个fedora实例,并连接到它的 tty 上的bash shell。
|
||||||
|
|
||||||
|
# docker run -i -t fedora bash
|
||||||
|
|
||||||
|
![Downloading Fedora Base Image](http://blog.linoxide.com/wp-content/uploads/2015/03/downloading-fedora-base-image.png)
|
||||||
|
|
||||||
|
### 2.安装Apache网络服务器 ###
|
||||||
|
|
||||||
|
现在,在我们的Fedora基本镜像实例准备好后,我们将会开始交互式地安装Apache网络服务器,而不是为它创建Dockerfile。为了做到这点,我们需要在终端或者shell运行以下命令。
|
||||||
|
|
||||||
|
# yum update
|
||||||
|
|
||||||
|
![Installing httpd](http://blog.linoxide.com/wp-content/uploads/2015/03/installing-httpd2.png)
|
||||||
|
|
||||||
|
# yum install httpd
|
||||||
|
|
||||||
|
![Installing httpd](http://blog.linoxide.com/wp-content/uploads/2015/03/installing-httpd2.png)
|
||||||
|
|
||||||
|
# exit
|
||||||
|
|
||||||
|
### 3.保存镜像 ###
|
||||||
|
|
||||||
|
现在,我们要去保存在Fedora实例里做的修改。要做到这个,我们首先需要知道实例的容器ID。而为了得到ID,我们又需要运行以下命令(LCTT 译注:在容器外执行该命令)。
|
||||||
|
|
||||||
|
# docker ps -a
|
||||||
|
|
||||||
|
![Docker Running Container](http://blog.linoxide.com/wp-content/uploads/2015/03/docker-running-container.png)
|
||||||
|
|
||||||
|
然后,我们会保存这些改变为一个新的镜像,请运行以下命令。
|
||||||
|
|
||||||
|
# docker commit c16378f943fe fedora-httpd
|
||||||
|
|
||||||
|
![committing fedora httpd](http://blog.linoxide.com/wp-content/uploads/2015/03/committing-fedora-httpd.png)
|
||||||
|
|
||||||
|
这里,修改已经通过使用容器ID保存起来了,镜像名字叫fedora-httpd。为了确认新的镜像是否在运行,我们将运行以下命令。
|
||||||
|
|
||||||
|
# docker images
|
||||||
|
|
||||||
|
![view docker images](http://blog.linoxide.com/wp-content/uploads/2015/03/view-docker-images.png)
|
||||||
|
|
||||||
|
### 4. 添加内容到新的镜像 ###
|
||||||
|
|
||||||
|
我们自己新的Fedora Apache镜像正成功的运行,现在我们想添加一些我们网站的网页内容到Apache网络服务器,使得网站能够开箱即用。为做到这点,我们需要创建一个新的Dockerfile,它会处理从复制网页内容到启用80端口的所有操作。要达到这样的目的,我们需要使用我们最喜欢的文本编辑器创建Dockerfile文件,像下面演示的一样。
|
||||||
|
|
||||||
|
# nano Dockerfile
|
||||||
|
|
||||||
|
现在,我们需要添加以下的命令行到文件中。
|
||||||
|
|
||||||
|
FROM fedora-httpd
|
||||||
|
ADD mysite.tar /tmp/
|
||||||
|
RUN mv /tmp/mysite/* /var/www/html
|
||||||
|
EXPOSE 80
|
||||||
|
ENTRYPOINT [ "/usr/sbin/httpd" ]
|
||||||
|
CMD [ "-D", "FOREGROUND" ]
|
||||||
|
|
||||||
|
![configuring Dockerfile](http://blog.linoxide.com/wp-content/uploads/2015/03/configuring-Dockerfile.png)
|
||||||
|
|
||||||
|
这里,上述的Dockerfile中,放在mysite.tar里的网页内容会自动解压到/tmp/文件夹里。然后,整个站点会被移动到Apache的网页根目录/var/www/html/,命令expose 80会打开80端口,这样网站就能正常访问了。其次,入口点放在了/usr/sbin/https里面,保证Apache服务器能够执行。
|
||||||
|
|
||||||
|
### 5. 构建并运行一个容器 ###
|
||||||
|
|
||||||
|
现在,我们要用刚刚创建的Dockerfile创建我们的容器,以便将我们的网站添加到上面。为做到这,我们需要运行以下命令。
|
||||||
|
|
||||||
|
# docker build -rm -t mysite .
|
||||||
|
|
||||||
|
![Building mysite Image](http://blog.linoxide.com/wp-content/uploads/2015/03/building-mysite-image.png)
|
||||||
|
|
||||||
|
建立好我们的新容器后,我们需要要用下面的命令来运行容器。
|
||||||
|
|
||||||
|
# docker run -d -P mysite
|
||||||
|
|
||||||
|
![Running mysite Container](http://blog.linoxide.com/wp-content/uploads/2015/03/running-mysite-container.png)
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
最后,我们已经成功的以交互式的方式建立了一个Docker容器。在本节方法中,我们是直接通过交互的shell命令建立我们的容器和镜像。在建立与配置镜像与容器时,这种方法十分简单且快速。如果你有任何问题,建议和反馈,请在下方的评论框里写下来,以便我们可以提升或者更新我们的文章。谢谢!祝生活快乐 :-)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://linoxide.com/linux-how-to/interactively-create-docker-container/
|
||||||
|
|
||||||
|
作者:[Arun Pyasi][a]
|
||||||
|
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://linoxide.com/author/arunp/
|
||||||
|
[1]:https://registry.hub.docker.com/
|
250
published/201505/20150326 How to set up server monitoring system with Monit.md
Executable file
250
published/201505/20150326 How to set up server monitoring system with Monit.md
Executable file
@ -0,0 +1,250 @@
|
|||||||
|
如何使用Monit部署服务器监控系统
|
||||||
|
================================================================================
|
||||||
|
很多Linux系统管理员依赖一个集中式的远程监控系统(比如[Nagios][1]或者[Cacti][2])来检查他们网络基础设备的健康状况。虽然集中式监控让管理员的生活更简单了,然而处理很多机器和服务时,专用的监控中心显然成为了一个单点故障,如果监控中心挂了或者因为什么原因(比如硬件或者网络故障)不可访问了,你就会失去整个网络基础设备情况的任何信息。
|
||||||
|
|
||||||
|
一个给你的监控系统增加冗余度的方法是安装独立的监控软件(作为后备),至少在网络中的关键/核心服务器上。这样在集中式监控系统挂掉的情况,你还有能力通过后备的监控方式来获取核心服务器的运行状况。
|
||||||
|
|
||||||
|
### Monit是什么? ###
|
||||||
|
|
||||||
|
[Monit][3]是一个跨平台的用来监控Unix/linux系统(比如Linux、BSD、OSX、Solaris)的工具。Monit特别易于安装,而且非常轻量级(只有500KB大小),并且不依赖任何第三方程序、插件或者库。然而,Monit可以胜任全面监控、进程状态监控、文件系统变动监控、邮件通知和对核心服务的自定义动作等场景。易于安装、轻量级的实现以及强大的功能,让Monit成为一个理想的后备监控工具。
|
||||||
|
|
||||||
|
我已经在一些机器使用Monit几年了,而且我对它的可靠性非常满意。甚至作为全面的监控系统,对任何Linux系统管理员来说Monit也是非常有用和强大的。在这篇教程中,我会展示如何在一个本地服务器部署Monit(作为后备监控系统)来监控常见的服务。在部署过程中,我只会展示我们用到的部分。
|
||||||
|
|
||||||
|
### 在Linux安装Monit ###
|
||||||
|
|
||||||
|
Monit已经被包含在多数Linux发行版的软件仓库中了。
|
||||||
|
|
||||||
|
Debian、Ubuntu或者Linux Mint:
|
||||||
|
|
||||||
|
$ sudo aptitude install monit
|
||||||
|
|
||||||
|
Fedora或者CentOS/RHEL:
|
||||||
|
|
||||||
|
在CentOS/RHEL中,你必须首先启用[EPEL][4]或者[Repoforge][5]软件仓库.
|
||||||
|
|
||||||
|
# yum install monit
|
||||||
|
|
||||||
|
Monit自带一个文档完善的配置文件,其中包含了很多例子。主配置文件在/etc/monit.conf(Fedora/CentOS/RHEL 中),或者/etc/monit/monitrc(Debian/Ubuntu/Mint 中)。Monit配置文件有两部分:“Global”(全局)和“Services”(服务)。
|
||||||
|
|
||||||
|
### Global Configuration: Web Status Page (全局配置:Web状态页面) ###
|
||||||
|
|
||||||
|
Monit可以使用邮件服务来发送通知,也可以使用HTTP/HTTPS页面来展示。我们先使用如下配置的web状态页面吧:
|
||||||
|
|
||||||
|
- Monit监听1966端口。
|
||||||
|
- 对web状态页面的访问是通过SSL加密的。
|
||||||
|
- 使用monituser/romania作为用户名/口令登录。
|
||||||
|
- 只允许通过localhost、myhost.mydomain.ro和在局域网内部(192.168.0.0/16)访问。
|
||||||
|
- Monit使用pem格式的SSL证书。
|
||||||
|
|
||||||
|
之后的步骤,我会使用一个基于Red Hat的系统。在基于Debian的系统中的步骤也是类似的。
|
||||||
|
|
||||||
|
首先,在/var/cert生成一个自签名的证书(monit.pem):
|
||||||
|
|
||||||
|
# mkdir /var/certs
|
||||||
|
# cd /etc/pki/tls/certs
|
||||||
|
# ./make-dummy-cert monit.pem
|
||||||
|
# cp monit.pem /var/certs
|
||||||
|
# chmod 0400 /var/certs/monit.pem
|
||||||
|
|
||||||
|
现在将下列代码片段放到Monit的主配置文件中。你可以创建一个空配置文件,或者基于自带的配置文件修改。
|
||||||
|
|
||||||
|
set httpd port 1966 and
|
||||||
|
SSL ENABLE
|
||||||
|
PEMFILE /var/certs/monit.pem
|
||||||
|
allow monituser:romania
|
||||||
|
allow localhost
|
||||||
|
allow 192.168.0.0/16
|
||||||
|
allow myhost.mydomain.ro
|
||||||
|
|
||||||
|
### Global Configuration: Email Notification (全局配置:邮件通知) ###
|
||||||
|
|
||||||
|
然后,我们来设置Monit的邮件通知。我们至少需要一个可用的[SMTP服务器][6]来让Monit发送邮件。这样就可以(按照你的实际情况修改):
|
||||||
|
|
||||||
|
- 邮件服务器的机器名:smtp.monit.ro
|
||||||
|
- Monit使用的发件人:monit@monit.ro
|
||||||
|
- 邮件的收件人:guletz@monit.ro
|
||||||
|
- 邮件服务器使用的SMTP端口:587(默认是25)
|
||||||
|
|
||||||
|
有了以上信息,邮件通知就可以这样配置:
|
||||||
|
|
||||||
|
set mailserver smtp.monit.ro port 587
|
||||||
|
set mail-format {
|
||||||
|
from: monit@monit.ro
|
||||||
|
subject: $SERVICE $EVENT at $DATE on $HOST
|
||||||
|
message: Monit $ACTION $SERVICE $EVENT at $DATE on $HOST : $DESCRIPTION.
|
||||||
|
|
||||||
|
Yours sincerely,
|
||||||
|
Monit
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
set alert guletz@monit.ro
|
||||||
|
|
||||||
|
就像你看到的,Monit会提供几个内部变量(`$DATE`、`$EVENT`、`$HOST`等),你可以按照你的需求自定义邮件内容。如果你想要从Monit所在机器发送邮件,就需要一个已经安装的与sendmail兼容的程序(如postfix或者ssmtp)。
|
||||||
|
|
||||||
|
### Global Configuration: Monit Daemon (全局配置:Monit守护进程)###
|
||||||
|
|
||||||
|
接下来就该配置Monit守护进程了。可以将其设置成这样:
|
||||||
|
|
||||||
|
- 在120秒后进行第一次检测。
|
||||||
|
- 每3分钟检测一次服务。
|
||||||
|
- 使用syslog来记录日志。
|
||||||
|
|
||||||
|
如下代码段可以满足上述需求。
|
||||||
|
|
||||||
|
set daemon 120
|
||||||
|
with start delay 240
|
||||||
|
set logfile syslog facility log_daemon
|
||||||
|
|
||||||
|
我们必须定义“idfile”,Monit守护进程的一个独一无二的ID文件;以及“eventqueue”,当monit的邮件因为SMTP或者网络故障发不出去,邮件会暂存在这里;以及确保/var/monit路径是存在的。然后使用下边的配置就可以了。
|
||||||
|
|
||||||
|
set idfile /var/monit/id
|
||||||
|
set eventqueue
|
||||||
|
basedir /var/monit
|
||||||
|
|
||||||
|
### 测试全局配置 ###
|
||||||
|
|
||||||
|
现在“Global”部分就完成了。Monit配置文件看起来像这样:
|
||||||
|
|
||||||
|
# Global Section
|
||||||
|
|
||||||
|
# status webpage and acl's
|
||||||
|
set httpd port 1966 and
|
||||||
|
SSL ENABLE
|
||||||
|
PEMFILE /var/certs/monit.pem
|
||||||
|
allow monituser:romania
|
||||||
|
allow localhost
|
||||||
|
allow 192.168.0.0/16
|
||||||
|
allow myhost.mydomain.ro
|
||||||
|
|
||||||
|
# mail-server
|
||||||
|
set mailserver smtp.monit.ro port 587
|
||||||
|
# email-format
|
||||||
|
set mail-format {
|
||||||
|
from: monit@monit.ro
|
||||||
|
subject: $SERVICE $EVENT at $DATE on $HOST
|
||||||
|
message: Monit $ACTION $SERVICE $EVENT at $DATE on $HOST : $DESCRIPTION.
|
||||||
|
|
||||||
|
Yours sincerely,
|
||||||
|
Monit
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
set alert guletz@monit.ro
|
||||||
|
|
||||||
|
# delay checks
|
||||||
|
set daemon 120
|
||||||
|
with start delay 240
|
||||||
|
set logfile syslog facility log_daemon
|
||||||
|
|
||||||
|
# idfile and mail queue path
|
||||||
|
set idfile /var/monit/id
|
||||||
|
set eventqueue
|
||||||
|
basedir /var/monit
|
||||||
|
|
||||||
|
现在是时候验证我们的工作了,你可以通过运行如下命令来验证存在的配置文件(/etc/monit.conf):
|
||||||
|
|
||||||
|
# monit -t
|
||||||
|
|
||||||
|
Control file syntax OK
|
||||||
|
|
||||||
|
如果monit提示任何错误,请再检查下配置文件。幸运的是,错误/警告信息是可以帮助你发现问题的,比如:
|
||||||
|
|
||||||
|
monit: Cannot stat the SSL server PEM file '/var/certs/monit.pem' -- No such file or directory
|
||||||
|
/etc/monit/monitrc:10: Warning: hostname did not resolve 'smtp.monit.ro'
|
||||||
|
|
||||||
|
一旦你确认配置文件没问题了,可以启动monit守护进程,然后等2到3分钟:
|
||||||
|
|
||||||
|
# service monit start
|
||||||
|
|
||||||
|
如果你使用的是systemd,运行:
|
||||||
|
|
||||||
|
# systemctl start monit
|
||||||
|
|
||||||
|
现在打开一个浏览器窗口,然后访问`https://<monit_host>:1966`。将`<monit_host>`替换成Monit所在机器的机器名或者IP地址。
|
||||||
|
|
||||||
|
如果你使用的是自签名的SSL证书,你会在浏览器中看到一个警告信息。继续访问即可。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7596/16737206479_96b9f7dfdb_c.jpg)
|
||||||
|
|
||||||
|
你完成登录后,就会看到这个页面。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7594/16303369973_6019482dea_c.jpg)
|
||||||
|
|
||||||
|
在这个教程的其余部分,我们演示监控一个本地服务器和常见服务的方法。你会在[官方wiki页面][7]看到很多有用的例子。其中的多数是可以直接复制粘贴的!
|
||||||
|
|
||||||
|
### Service Configuration: CPU/Memory Monitoring (服务配置:CPU、内存监控) ###
|
||||||
|
|
||||||
|
我们先来监控本地服务器的CPU、内存占用。复制如下代码段到配置文件中。
|
||||||
|
|
||||||
|
check system localhost
|
||||||
|
if loadavg (1min) > 10 then alert
|
||||||
|
if loadavg (5min) > 6 then alert
|
||||||
|
if memory usage > 75% then alert
|
||||||
|
if cpu usage (user) > 70% then alert
|
||||||
|
if cpu usage (system) > 60% then alert
|
||||||
|
if cpu usage (wait) > 75% then alert
|
||||||
|
|
||||||
|
你可以很容易理解上边的配置。最上边的check是指每个监控周期(全局配置里设置的120秒)都对本机进行下面的操作。如果满足了任何条件,monit守护进程就会使用邮件发送一条报警。
|
||||||
|
|
||||||
|
如果某个监控项不需要每个周期都检查,可以使用如下格式,它会每240秒检查一次平均负载。
|
||||||
|
|
||||||
|
if loadavg (1min) > 10 for 2 cycles then alert
|
||||||
|
|
||||||
|
### Service Configuration: SSH Service Monitoring (服务配置:SSH服务监控) ###
|
||||||
|
|
||||||
|
先检查我们的sshd是否安装在/usr/sbin/sshd:
|
||||||
|
|
||||||
|
check file sshd_bin with path /usr/sbin/sshd
|
||||||
|
|
||||||
|
我们还想检查sshd的启动脚本是否存在:
|
||||||
|
|
||||||
|
check file sshd_init with path /etc/init.d/sshd
|
||||||
|
|
||||||
|
最后,我们还想检查sshd守护进程是否存活,并且在监听22端口:
|
||||||
|
|
||||||
|
check process sshd with pidfile /var/run/sshd.pid
|
||||||
|
start program "/etc/init.d/sshd start"
|
||||||
|
stop program "/etc/init.d/sshd stop"
|
||||||
|
if failed port 22 protocol ssh then restart
|
||||||
|
if 5 restarts within 5 cycles then timeout
|
||||||
|
|
||||||
|
我们可以这样解释上述配置:我们检查是否存在名为sshd的进程,并且有一个保存其pid的文件存在(/var/run/sshd.pid)。如果任何一个不存在,我们就使用启动脚本重启sshd。我们检查是否有进程在监听22端口,并且使用的是SSH协议。如果没有,我们还是重启sshd。如果在最近的5个监控周期(5x120秒)至少重启5次了,sshd就被认为是不能用的,我们就不再检查了。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8685/16735725998_62c26a24bc_c.jpg)
|
||||||
|
|
||||||
|
### Service Configuration: SMTP Service Monitoring (服务配置:SMTP服务监控) ###
|
||||||
|
|
||||||
|
现在我们来设置一个检查远程SMTP服务器(如192.168.111.102)的监控。假定SMTP服务器运行着SMTP、IMAP、SSH服务。
|
||||||
|
|
||||||
|
check host MAIL with address 192.168.111.102
|
||||||
|
if failed icmp type echo within 10 cycles then alert
|
||||||
|
if failed port 25 protocol smtp then alert
|
||||||
|
else if recovered then exec "/scripts/mail-script"
|
||||||
|
if failed port 22 protocol ssh then alert
|
||||||
|
if failed port 143 protocol imap then alert
|
||||||
|
|
||||||
|
我们检查远程主机是否响应ICMP协议。如果我们在10个周期内没有收到ICMP回应,就发送一条报警。如果监测到25端口上的SMTP协议是异常的,就发送一条报警。如果在一次监测失败后又监测成功了,就运行一个脚本(/scripts/mail-script)。如果检查22端口上的SSH或者143端口上的IMAP协议不正常,同样发送报警。
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
在这个教程,我演示了如何在本地服务器设置Monit,当然这只是Monit功能的冰山一角。你可以花些时间阅读Monit的man手册(写得很好)。Monit可以为任何Linux系统管理员做很多事情,并且具有非常优美和易于理解的语法。如果你将一个集中式的远程监控系统和Monit一同使用,你会得到一个更可靠的监控系统。你感觉Monit怎么样?
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/server-monitoring-system-monit.html
|
||||||
|
|
||||||
|
作者:[Iulian Murgulet][a]
|
||||||
|
译者:[goreliu](https://github.com/goreliu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/iulian
|
||||||
|
[1]:http://xmodulo.com/monitor-common-services-nagios.html
|
||||||
|
[2]:http://xmodulo.com/monitor-linux-servers-snmp-cacti.html
|
||||||
|
[3]:http://mmonit.com/monit/
|
||||||
|
[4]:https://linux.cn/article-2324-1.html
|
||||||
|
[5]:http://xmodulo.com/how-to-set-up-rpmforge-repoforge-repository-on-centos.html
|
||||||
|
[6]:http://xmodulo.com/mail-server-ubuntu-debian.html
|
||||||
|
[7]:http://mmonit.com/wiki/Monit/ConfigurationExamples
|
@ -1,10 +1,10 @@
|
|||||||
使用 SSH 和一次性密码安全登录 Linux
|
使用一次性密码本通过 SSH 安全登录 Linux
|
||||||
================================================================================
|
================================================================================
|
||||||
有人说,安全不是一个产品,而是一个过程(LCTT 注:安全公司 McAfee 认为,安全风险管理是一个方法论,而不是安全产品的堆叠)。虽然 SSH 协议被设计成使用加密技术来确保安全,但如果使用不当,别人还是能够破坏你的系统:比如弱密码、密钥泄露、使用的 SSH 客户端过时等,都能引发安全问题。
|
有人说,安全不是一个产品,而是一个过程(LCTT 注:安全公司 McAfee 认为,安全风险管理是一个方法论,而不是安全产品的堆叠)。虽然 SSH 协议被设计成使用加密技术来确保安全,但如果使用不当,别人还是能够破坏你的系统:比如弱密码、密钥泄露、使用过时的 SSH 客户端等,都能引发安全问题。
|
||||||
|
|
||||||
在考虑 SSH 认证方案时,大家普遍认为[公钥认证][1]比密码认证更安全。然而,公钥认证技术并不是为公共环境设置的,如果你在一台公用电脑上使用公钥认证登录 SSH 服务器,你的服务器已经毫无安全可言了,公用的电脑可能会记录你的公钥,或从你的内存中读取公钥。如果你不信任本地电脑,那你最好还是使用其他方式登录服务器。现在就是“一次性密码”派上用场的时候了,就像名字所示,一次性密码只能被使用一次。这种一次性密码非常合适在不安全的环境下发挥作用,就算它被窃取,也无法再次使用。
|
在考虑 SSH 认证方案时,大家普遍认为[公钥认证][1]比密码认证更安全。然而,公钥认证技术并不是为公共环境设置的,如果你在一台公用电脑上使用公钥认证登录 SSH 服务器,你的服务器已经毫无安全可言了,公用的电脑可能会记录你的公钥,或从你的内存中读取公钥。如果你不信任本地电脑,那你最好还是使用其他方式登录服务器。现在就是“一次性密码(OTP)”派上用场的时候了,就像名字所示,一次性密码只能被使用一次。这种一次性密码非常合适在不安全的环境下发挥作用,就算它被窃取,也无法再次使用。
|
||||||
|
|
||||||
有个一次性密码方案叫[谷歌认证][2],但在本文中,我要介绍的是另一种 SSH 登录方案:[OTPW][3],它是个一次性密码登录的软件包。不像谷歌认证,OTPW 不需要依赖任何第三方库。
|
有个生成一次性密码的方法是通过[谷歌认证器][2],但在本文中,我要介绍的是另一种 SSH 登录方案:[OTPW][3],它是个一次性密码登录的软件包。不像谷歌认证,OTPW 不需要依赖任何第三方库。
|
||||||
|
|
||||||
### OTPW 是什么 ###
|
### OTPW 是什么 ###
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ OTPW 由一次性密码生成器和 PAM 认证规则组成。在 OTPW 中一次
|
|||||||
$ git clone https://www.cl.cam.ac.uk/~mgk25/git/otpw
|
$ git clone https://www.cl.cam.ac.uk/~mgk25/git/otpw
|
||||||
$ cd otpw
|
$ cd otpw
|
||||||
|
|
||||||
打开 Makefile 文件,编辑以“PAMLIB=”开头的那行配置:
|
打开 Makefile 文件,编辑以“PAMLIB=”开头的那行配置:
|
||||||
|
|
||||||
64 位系统:
|
64 位系统:
|
||||||
|
|
||||||
@ -49,12 +49,12 @@ OTPW 由一次性密码生成器和 PAM 认证规则组成。在 OTPW 中一次
|
|||||||
|
|
||||||
PAMLIB=/usr/lib/security
|
PAMLIB=/usr/lib/security
|
||||||
|
|
||||||
编译安装。需要注意的是安装过程会把 SSH 服务重启一下,所以如果你是使用 SSH 连接到服务器,做好被断开连接的准备吧。
|
编译安装。需要注意的是安装过程会自动重启 SSH 服务一下,所以如果你是使用 SSH 连接到服务器,做好被断开连接的准备吧(LCTT 译注:也许不会被断开连接,即便被断开连接,请使用原来的方式重新连接即可,现在还没有换成一次性口令方式。)。
|
||||||
|
|
||||||
$ make
|
$ make
|
||||||
$ sudo make install
|
$ sudo make install
|
||||||
|
|
||||||
现在你需要更新 SELinux 策略,因为 /usr/sbin/sshd 会往你的 home 目录写数据,而 SELinux 默认是不允许这么做的。如果你使用了 SELinux 服务(LCTT 注:使用 getenforce 命令查看结果,如果是 enforcing,就是打开了 SELinux 服务),如果没有使用 SELinux 服务,请跳过这一步。
|
现在你需要更新 SELinux 策略,因为 /usr/sbin/sshd 会往你的 home 目录写数据,而 SELinux 默认是不允许这么做的。如果没有使用 SELinux 服务(LCTT 注:使用 getenforce 命令查看结果,如果是 enforcing,就是打开了 SELinux 服务),请跳过这一步。
|
||||||
|
|
||||||
$ sudo grep sshd /var/log/audit/audit.log | audit2allow -M mypol
|
$ sudo grep sshd /var/log/audit/audit.log | audit2allow -M mypol
|
||||||
$ sudo semodule -i mypol.pp
|
$ sudo semodule -i mypol.pp
|
||||||
@ -90,6 +90,8 @@ Debian, Ubuntu 或 Linux Mint 发行版:
|
|||||||
Fedora 或 CentOS/RHEL 7 发行版:
|
Fedora 或 CentOS/RHEL 7 发行版:
|
||||||
|
|
||||||
$ sudo systemctl restart sshd
|
$ sudo systemctl restart sshd
|
||||||
|
|
||||||
|
(LCTT 译注:虽然这里重启了 sshd 服务,但是你当前的 ssh 连接应该不受影响,只是在你完成下述步骤之前,无法按照原有方式建立新的连接了。因此,保险起见,要么多开一个 ssh 连接,避免误退出当前连接;要么将重启 sshd 服务器步骤放到步骤3完成之后。)
|
||||||
|
|
||||||
#### 步骤3:使用 OTPW 产生一次性密码 ####
|
#### 步骤3:使用 OTPW 产生一次性密码 ####
|
||||||
|
|
||||||
@ -102,7 +104,7 @@ Fedora 或 CentOS/RHEL 7 发行版:
|
|||||||
|
|
||||||
这个命令会让你输入密码前缀,当你以后登录的时候,你需要同时输入这个前缀以及一次性密码。密码前缀是另外一层保护,就算你的一次性密码表被泄漏,别人也无法通过暴力破解你的 SSH 密码。
|
这个命令会让你输入密码前缀,当你以后登录的时候,你需要同时输入这个前缀以及一次性密码。密码前缀是另外一层保护,就算你的一次性密码表被泄漏,别人也无法通过暴力破解你的 SSH 密码。
|
||||||
|
|
||||||
设置好密码前缀后,这个命令会产生 280 个一次性密码,并将它们保存在一个文本文件中(如 temporary_password.txt)。每个密码(默认是 8 个字符)由一个 3 位十进制数索引。你需要将这个密码表打印出来,并随身携带。
|
设置好密码前缀后,这个命令会产生 280 个一次性密码(LCTT 译注:保存到 ~/.otpw 下),并将它们导出到一个文本文件中(如 temporary_password.txt)。每个密码(默认是 8 个字符)由一个 3 位十进制数索引。你需要将这个密码表打印出来,并随身携带。
|
||||||
|
|
||||||
![](https://farm8.staticflickr.com/7281/16962594055_c2696d5ae1_b.jpg)
|
![](https://farm8.staticflickr.com/7281/16962594055_c2696d5ae1_b.jpg)
|
||||||
|
|
||||||
@ -160,7 +162,7 @@ Fedora 或 CentOS/RHEL 7 发行版:
|
|||||||
|
|
||||||
### 总结 ###
|
### 总结 ###
|
||||||
|
|
||||||
在这个教程中,我介绍了如何使用 OTPW 工具来设置一次性登录密码。你也许意识到了在这种两个因子的认证方式中,打印一张密码表让人感觉好 low,但是这种方式是最简单的,并且不用依赖任何第三方软件。无论你用哪种方式创建一次性密码,在你需要在一个不被信任的环境登录 SSH 服务器的时候,它们都很有用。你可以就这个主题来分享你的经验和观点。
|
在这个教程中,我介绍了如何使用 OTPW 工具来设置一次性登录密码。你也许意识到了在这种双因子的认证方式中,打印一张密码表让人感觉好 low,但是这种方式是最简单的,并且不用依赖任何第三方软件。无论你用哪种方式创建一次性密码,在你需要在一个不可信任的环境登录 SSH 服务器的时候,它们都很有用。你可以就这个主题来分享你的经验和观点。
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -168,11 +170,11 @@ via: http://xmodulo.com/secure-ssh-login-one-time-passwords-linux.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[bazz2](https://github.com/bazz2)
|
译者:[bazz2](https://github.com/bazz2)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
[a]:http://xmodulo.com/author/nanni
|
[a]:http://xmodulo.com/author/nanni
|
||||||
[1]:http://xmodulo.com/how-to-force-ssh-login-via-public-key-authentication.html
|
[1]:https://linux.cn/article-5444-1.html
|
||||||
[2]:http://xmodulo.com/two-factor-authentication-ssh-login-linux.html
|
[2]:https://linux.cn/article-2642-1.html
|
||||||
[3]:http://www.cl.cam.ac.uk/~mgk25/otpw.html
|
[3]:http://www.cl.cam.ac.uk/~mgk25/otpw.html
|
@ -1,8 +1,8 @@
|
|||||||
Linux有问必答-- 如何在Ubuntu中升级Docker
|
Linux有问必答:如何在Ubuntu中升级Docker
|
||||||
================================================================================
|
================================================================================
|
||||||
> **提问**: 我使用了Ubuntu的标准仓库安装了Docker。然而,默认安装的Docker不能满足我另外一个依赖Docker程序的版本需要。我该如何在Ubuntu中升级到Docker的最新版本?
|
> **提问**: 我使用了Ubuntu的标准仓库安装了Docker。然而,默认安装的Docker不能满足我另外一个依赖Docker程序的版本需要。我该如何在Ubuntu中升级到Docker的最新版本?
|
||||||
|
|
||||||
Docker第一次在2013年发布,它快速地演变成了一个针对分布式程序的开发平台。为了满足工业期望,Docker正在紧密地开发并持续地带来新特性的升级。这样Ubuntu发行版中的Docker版本可能很快就会过时。比如,, Ubuntu 14.10 Utopic 中的Docker版本是1.2.0, 然而最新的Docker版本是1.5.0。
|
Docker第一次在2013年发布,它快速地演变成了一个针对分布式程序的开发平台。为了满足工业期望,Docker正在紧密地开发并持续地带来新特性的升级。这样Ubuntu发行版中的Docker版本可能很快就会过时。比如, Ubuntu 14.10 Utopic 中的Docker版本是1.2.0, 然而最新的Docker版本是1.6.0。
|
||||||
|
|
||||||
![](https://farm9.staticflickr.com/8730/16351300024_9acb9086da_b.jpg)
|
![](https://farm9.staticflickr.com/8730/16351300024_9acb9086da_b.jpg)
|
||||||
|
|
||||||
@ -28,7 +28,7 @@ via: http://ask.xmodulo.com/upgrade-docker-ubuntu.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[geekpi](https://github.com/geekpi)
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,151 @@
|
|||||||
|
Conky - 终极的 X 视窗系统监视器应用
|
||||||
|
================================================================================
|
||||||
|
Conky 是一个用 ‘C’ 语言写就的系统监视器,并在 GNU GPL 和 BSD 许可协议下发布,在 Linux 和 BSD 操作系统中都可以获取到它。这个应用是基于 X 视窗系统的,原本由 [Torsmo][1] 分支而来。
|
||||||
|
|
||||||
|
#### 特点 ####
|
||||||
|
|
||||||
|
- 简洁的用户界面;
|
||||||
|
- 高度可配置;
|
||||||
|
- 它既可使用内置的部件(超过 300 多个) 也可使用外部脚本,来在桌面或其自有容器中展示系统的状态;
|
||||||
|
- 低资源消耗;
|
||||||
|
- 它可显示范围广泛的系统参数,包括但不限于 CPU,内存,swap 分区 ,温度,进程,磁盘使用情况,网络状态,电池电量,邮件收发,系统消息,音乐播放器的控制,天气信息,最新新闻,升级信息等等;
|
||||||
|
- 在许多操作系统中如 CrunchBang Linux 和 Pinguy OS 被默认安装;
|
||||||
|
|
||||||
|
#### 关于 Conky 的少有人知的事实 ####
|
||||||
|
|
||||||
|
- conky 这个名称来自于一个加拿大电视节目;
|
||||||
|
- 它已被移植到 Nokia N900 上;
|
||||||
|
- 官方已经不再维护它了;
|
||||||
|
|
||||||
|
### 在 Linux 中 Conky 的安装和使用 ###
|
||||||
|
|
||||||
|
在我们安装 conky 之前,我们需要使用下面的命令来安装诸如 `lm-sensors`, `curl` 和 `hddtemp` 之类的软件包:
|
||||||
|
|
||||||
|
# apt-get install lm-sensors curl hddtemp
|
||||||
|
|
||||||
|
然后是检测传感器:
|
||||||
|
|
||||||
|
# sensors-detect
|
||||||
|
|
||||||
|
**注**: 在被系统提示时,回答 ‘Yes’ 。
|
||||||
|
|
||||||
|
检测所有探测到的传感器:
|
||||||
|
|
||||||
|
# sensors
|
||||||
|
|
||||||
|
#### 样例输出 ####
|
||||||
|
|
||||||
|
acpitz-virtual-0
|
||||||
|
Adapter: Virtual device
|
||||||
|
temp1: +49.5°C (crit = +99.0°C)
|
||||||
|
|
||||||
|
coretemp-isa-0000
|
||||||
|
Adapter: ISA adapter
|
||||||
|
Physical id 0: +49.0°C (high = +100.0°C, crit = +100.0°C)
|
||||||
|
Core 0: +49.0°C (high = +100.0°C, crit = +100.0°C)
|
||||||
|
Core 1: +49.0°C (high = +100.0°C, crit = +100.0°C)
|
||||||
|
|
||||||
|
Conky 既可以从软件仓库中安装,也可从源代码编译得到:
|
||||||
|
|
||||||
|
# yum install conky [在 RedHat 系的系统上]
|
||||||
|
# apt-get install conky-all [在 Debian 系的系统上]
|
||||||
|
|
||||||
|
**注**: 在 Fedora/CentOS 上安装 conky 之前,你必须启用 [EPEL 软件仓库][2]。
|
||||||
|
|
||||||
|
在安装完 conky 之后,只需输入如下命令来开启它:
|
||||||
|
|
||||||
|
$ conky &
|
||||||
|
|
||||||
|
![正在运行的 Conky 监视器](http://www.tecmint.com/wp-content/uploads/2015/03/Start-Conkey.jpeg)
|
||||||
|
|
||||||
|
*正在运行的 Conky 监视器*
|
||||||
|
|
||||||
|
这使得 conky 以一个弹窗的形式运行,并使用位于 `/etc/conky/conky.conf` 的 conky 基本配置文件。
|
||||||
|
|
||||||
|
你可能想将 conky 集成到桌面上,并不想让它每次以弹窗的形式出现,下面就是你需要做的:
|
||||||
|
|
||||||
|
将配置文件 `/etc/conky/conky.conf` 复制到你的家目录中,并将它重命名为 `.conkyrc`,开头的点号 (.) 是为了确保这个配置文件是隐藏的。
|
||||||
|
|
||||||
|
$ cp /etc/conky/conky.conf /home/$USER/.conkyrc
|
||||||
|
|
||||||
|
现在重启 conky 来应用新的更改:
|
||||||
|
|
||||||
|
$ killall -SIGUSR1 conky
|
||||||
|
|
||||||
|
![Conky 监视器窗口](http://www.tecmint.com/wp-content/uploads/2015/03/Restart-Conky.jpeg)
|
||||||
|
|
||||||
|
*Conky 监视器窗口*
|
||||||
|
|
||||||
|
你可能想编辑位于你的家目录的 conky 的配置文件,这个配置文件的内容是非常容易理解的。
|
||||||
|
|
||||||
|
下面是 conky 配置文件的一个样例:
|
||||||
|
|
||||||
|
![Conky 的配置](http://www.tecmint.com/wp-content/uploads/2015/03/Conky-Configuration.jpeg)
|
||||||
|
|
||||||
|
*Conky 的配置*
|
||||||
|
|
||||||
|
从上面的窗口中,你可以更改颜色,边框,大小,缩放比例,背景,对齐方式及几个其他属性。通过为不同的 conky 窗口设定不同的对齐方式,我们可以同时运行几个 conky 脚本。
|
||||||
|
|
||||||
|
**让 conky 使用其它脚本而不是默认配置,以及如何找到这些脚本?**
|
||||||
|
|
||||||
|
你可以编写你自己的 conky 脚本或使用来自于互联网的脚本;我们并不建议你使用从互联网中找到的具有潜在危险的任何脚本,除非你清楚你正在做什么。然而,有一些著名的主题和网页包含可信赖的 conky 脚本,例如下面所提及的:
|
||||||
|
|
||||||
|
- [http://ubuntuforums.org/showthread.php?t=281865][3]
|
||||||
|
- [http://conky.sourceforge.net/screenshots.html][4]
|
||||||
|
|
||||||
|
在上面的 URL 地址中,你将发现其中每个截图都有一个超链接,它们将指向到脚本文件。
|
||||||
|
|
||||||
|
#### 测试 Conky 脚本 ####
|
||||||
|
|
||||||
|
这里我将在我的 Debian Jessie 系统中运行一个由第三方写的 conky 脚本,以此来进行测试:
|
||||||
|
|
||||||
|
$ wget https://github.com/alexbel/conky/archive/master.zip
|
||||||
|
$ unzip master.zip
|
||||||
|
|
||||||
|
切换当前工作目录到刚才解压的目录:
|
||||||
|
|
||||||
|
$ cd conky-master
|
||||||
|
|
||||||
|
将 `secrets.yml.example` 重命名为 `secrets.yml`:
|
||||||
|
|
||||||
|
$ mv secrets.yml.example secrets.yml
|
||||||
|
|
||||||
|
在你需要运行这个(ruby)脚本之前安装 Ruby:
|
||||||
|
|
||||||
|
$ sudo apt-get install ruby
|
||||||
|
$ ruby starter.rb
|
||||||
|
|
||||||
|
![华丽的 conky 外观](http://www.tecmint.com/wp-content/uploads/2015/03/Conky-Fancy-Look.jpeg)
|
||||||
|
|
||||||
|
*华丽的 conky 外观*
|
||||||
|
|
||||||
|
**注**: 可以修改这个脚本以展示你当前的天气,温度等;
|
||||||
|
|
||||||
|
假如你想让 conky 开机自启,请在开机启动应用设置(startup Applications) 中添加如下的几行命令:
|
||||||
|
|
||||||
|
conky --pause 10
|
||||||
|
save and exit.
|
||||||
|
|
||||||
|
最后,如此轻量级且吸引眼球的实用 GUI 软件包不再处于活跃状态且官方不再进行维护了。最新的稳定发布版本为 conky 1.9.0, 于 2012 年 5 月 3 号发布。在 Ubuntu 论坛上,一个有关用户分享 conky 配置的主题已经超过了 2000 多页。(这个论坛主题的链接为: [http://ubuntuforums.org/showthread.php?t=281865/][5])
|
||||||
|
|
||||||
|
- [Conky 主页][6]
|
||||||
|
|
||||||
|
这就是全部内容了。保持联系,保持评论。请在下面的评论框里分享你的想法和配置。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.tecmint.com/install-conky-in-ubuntu-debian-fedora/
|
||||||
|
|
||||||
|
作者:[Avishek Kumar][a]
|
||||||
|
译者:[FSSlc](https://github.com/FSSlc)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.tecmint.com/author/avishek/
|
||||||
|
[1]:http://torsmo.sourceforge.net/
|
||||||
|
[2]:https://linux.cn/article-2324-1.html
|
||||||
|
[3]:http://ubuntuforums.org/showthread.php?t=281865
|
||||||
|
[4]:http://conky.sourceforge.net/screenshots.html
|
||||||
|
[5]:http://ubuntuforums.org/showthread.php?t=281865/
|
||||||
|
[6]:http://conky.sourceforge.net/
|
@ -2,42 +2,45 @@
|
|||||||
================================================================================
|
================================================================================
|
||||||
我们一直积极地提供有关 Linux 技巧的系列文章,如果你错过了这个系列的最新文章,你或许可以去访问下面的链接。
|
我们一直积极地提供有关 Linux 技巧的系列文章,如果你错过了这个系列的最新文章,你或许可以去访问下面的链接。
|
||||||
|
|
||||||
注:此篇文章做过原文
|
- [Linux 中 5 个有趣的命令行技巧][1]
|
||||||
- [Linux 中 5 个有趣的命令行技巧][1] (注:这篇文章还没有被翻译,在 20150316 选的题)
|
|
||||||
|
|
||||||
在这篇文章中,我们将分享一些有趣 Linux 技巧,内容是有关如何产生随机密码以及加密或解密这些经过加盐或没有加盐处理的密码。
|
在这篇文章中,我们将分享一些有趣 Linux 技巧,内容是有关如何产生随机密码以及加密或解密这些经过加盐或没有加盐处理的密码。
|
||||||
|
|
||||||
安全是数字时代中的一个主要话题。在电脑,email,云端,手机,文档和其他的场合中,我们都会使用到密码。众所周知,选择密码的基本原则是 “易记,难猜”。考虑过使用基于机器自动生成的密码吗?相信我,Linux 非常擅长这方面的工作。
|
安全是数字时代中的一个主要话题。在电脑,email,云端,手机,文档和其他的场合中,我们都会使用到密码。众所周知,选择密码的基本原则是 “易记,难猜”。考虑过使用基于机器自动生成的密码吗?相信我,Linux 非常擅长这方面的工作。
|
||||||
|
|
||||||
**1. 使用命令 `pwgen` 来生成一个长度为 10 个字符的唯一的随机密码。假如你还没有安装 pwgen,请使用 Apt 或 YUM 等包管理器来安装它。**
|
**1. 使用命令 `pwgen` 来生成一个长度为 10 个字符的独特的随机密码。假如你还没有安装 pwgen,请使用 Apt 或 YUM 等包管理器来安装它。**
|
||||||
|
|
||||||
$ pwgen 10 1
|
$ pwgen 10 1
|
||||||
|
|
||||||
![生成一个唯一的随机密码](http://www.tecmint.com/wp-content/uploads/2015/03/Generate-Random-Unique-Password-in-Linux.gif)
|
![生成一个独特的随机密码](http://www.tecmint.com/wp-content/uploads/2015/03/Generate-Random-Unique-Password-in-Linux.gif)
|
||||||
生成一个唯一的随机密码
|
|
||||||
|
*生成一个独特的随机密码*
|
||||||
|
|
||||||
一口气生成若干组长度为 50 个字符的唯一的随机密码!
|
一口气生成若干组长度为 50 个字符的唯一的随机密码!
|
||||||
|
|
||||||
$ pwgen 50
|
$ pwgen 50
|
||||||
|
|
||||||
![生成多组随机密码](http://www.tecmint.com/wp-content/uploads/2015/03/Generate-Multiple-Random-Passwords.gif)
|
![生成多组随机密码](http://www.tecmint.com/wp-content/uploads/2015/03/Generate-Multiple-Random-Passwords.gif)
|
||||||
生成多组随机密码
|
|
||||||
|
|
||||||
**2. 你还可以使用 `makepasswd` 来每次生成一个给定长度的唯一的随机密码。在你把玩 makepasswd 命令之前,请确保你已经安装了它。如若没有安装它,试试使用 Apt 或 YUM 包管理器来安装 `makepasswd`这个软件包。**
|
*生成多组随机密码*
|
||||||
|
|
||||||
|
**2. 你还可以使用 `makepasswd` 来每次生成一个给定长度的独特的随机密码。在你把玩 makepasswd 命令之前,请确保你已经安装了它。如若没有安装它,试试使用 Apt 或 YUM 包管理器来安装 `makepasswd`这个软件包。**
|
||||||
|
|
||||||
生成一个长度为 10 个字符的随机密码。该命令产生的密码的长度默认为 10。
|
生成一个长度为 10 个字符的随机密码。该命令产生的密码的长度默认为 10。
|
||||||
|
|
||||||
$ makepasswd
|
$ makepasswd
|
||||||
|
|
||||||
![使用 makepasswd 生成唯一的密码](http://www.tecmint.com/wp-content/uploads/2015/03/mkpasswd-generate-unique-password.gif)
|
![使用 makepasswd 生成独特的密码](http://www.tecmint.com/wp-content/uploads/2015/03/mkpasswd-generate-unique-password.gif)
|
||||||
使用 makepasswd 生成唯一的密码
|
|
||||||
|
*使用 makepasswd 生成独特的密码*
|
||||||
|
|
||||||
生成一个长度为 50 个字符的随机密码。
|
生成一个长度为 50 个字符的随机密码。
|
||||||
|
|
||||||
$ makepasswd --char 50
|
$ makepasswd --char 50
|
||||||
|
|
||||||
![生成长度为 50 的密码](http://www.tecmint.com/wp-content/uploads/2015/03/Random-Password-Generate.gif)
|
![生成长度为 50 的密码](http://www.tecmint.com/wp-content/uploads/2015/03/Random-Password-Generate.gif)
|
||||||
生成长度为 50 的密码
|
|
||||||
|
*生成长度为 50 的密码*
|
||||||
|
|
||||||
生成 7 个长度为 20 个字符的随机密码。
|
生成 7 个长度为 20 个字符的随机密码。
|
||||||
|
|
||||||
@ -47,9 +50,7 @@
|
|||||||
|
|
||||||
**3. 使用带“盐”的 Crypt(注:这里应该指的是一个函数,可以参考[这里](http://man7.org/linux/man-pages/man3/crypt.3.html) ) 来加密一个密码。提供手动或自动添加 “盐”。**
|
**3. 使用带“盐”的 Crypt(注:这里应该指的是一个函数,可以参考[这里](http://man7.org/linux/man-pages/man3/crypt.3.html) ) 来加密一个密码。提供手动或自动添加 “盐”。**
|
||||||
|
|
||||||
对于那些不清楚 **盐** 的意义的人,
|
对于那些不清楚 **盐** 的意义的人,这里的 “盐” 指的是一个随机数据,它作为密码生成函数的一个额外的输入, 目的是保护密码免受词典攻击。
|
||||||
|
|
||||||
这里的 “盐” 指的是一个随机数据,它作为密码生成函数的一个额外的输入, 目的是保护密码免受词典攻击。
|
|
||||||
|
|
||||||
在执行下面的操作前,请确保你已经安装了 `mkpasswd`。
|
在执行下面的操作前,请确保你已经安装了 `mkpasswd`。
|
||||||
|
|
||||||
@ -58,46 +59,51 @@
|
|||||||
$ mkpasswd tecmint
|
$ mkpasswd tecmint
|
||||||
|
|
||||||
![使用 Crypt 来加密密码](http://www.tecmint.com/wp-content/uploads/2015/03/Encrypt-Password-in-Linux.gif)
|
![使用 Crypt 来加密密码](http://www.tecmint.com/wp-content/uploads/2015/03/Encrypt-Password-in-Linux.gif)
|
||||||
使用 Crypt 来加密密码
|
|
||||||
|
*使用 Crypt 来加密密码*
|
||||||
|
|
||||||
现在让我们来手动定义 “盐” 的值。每次它将产生相同的结果。请注意你可以输入任何你想输入的值来作为 “盐” 的值。
|
现在让我们来手动定义 “盐” 的值。每次它将产生相同的结果。请注意你可以输入任何你想输入的值来作为 “盐” 的值。
|
||||||
|
|
||||||
$ mkpasswd tecmint -s tt
|
$ mkpasswd tecmint -s tt
|
||||||
|
|
||||||
![带“盐”加密密码](http://www.tecmint.com/wp-content/uploads/2015/03/Encrypt-Password-Using-Salt.gif)
|
![带“盐”加密密码](http://www.tecmint.com/wp-content/uploads/2015/03/Encrypt-Password-Using-Salt.gif)
|
||||||
带“盐”加密密码
|
|
||||||
|
*带“盐”加密密码*
|
||||||
|
|
||||||
另外, mkpasswd 还是交互式的,假如你在命令中没有提供密码,它将主动询问你来输入密码。
|
另外, mkpasswd 还是交互式的,假如你在命令中没有提供密码,它将主动询问你来输入密码。
|
||||||
|
|
||||||
**4. 使用 aes-256-cbc 加密算法并使用密码(如 “tecmint”) 并带“盐” 加密一个字符串(如 “Tecmint-is-a-Linux-Community”)。**
|
**4. 使用 aes-256-cbc 加密算法并使用带“盐”的密码(如 “tecmint”) 加密一个字符串(如 “Tecmint-is-a-Linux-Community”)。**
|
||||||
|
|
||||||
# echo Tecmint-is-a-Linux-Community | openssl enc -aes-256-cbc -a -salt -pass pass:tecmint
|
# echo Tecmint-is-a-Linux-Community | openssl enc -aes-256-cbc -a -salt -pass pass:tecmint
|
||||||
|
|
||||||
![在 Linux 中加密一个字符串](http://www.tecmint.com/wp-content/uploads/2015/03/Encrypt-A-String-in-Linux.gif)
|
![在 Linux 中加密一个字符串](http://www.tecmint.com/wp-content/uploads/2015/03/Encrypt-A-String-in-Linux.gif)
|
||||||
在 Linux 中加密一个字符串
|
|
||||||
|
|
||||||
在上面例子中, [echo 命令][2](注:此篇原文也做过,这里是链接 http://linux.cn/article-3948-1.html) 的输出通过管道传递给了 openssl 命令,使得该输出被 Cipher(enc) 所加密,这个过程中使用了 aes-256-cbc 加密算法,并附带了密码 (tecmint) 和 “盐” 。
|
*在 Linux 中加密一个字符串*
|
||||||
|
|
||||||
|
在上面例子中, [echo 命令][2]的输出通过管道传递给了 openssl 命令,使得该输出通过加密编码方式(enc:Encoding with Cipher ) 所加密,这个过程中使用了 aes-256-cbc 加密算法,并附带了密码 (tecmint) 和 “盐” 。
|
||||||
|
|
||||||
**5. 使用 openssl 命令的 -aes-256-cbc 解密选项来解密上面的字符串。**
|
**5. 使用 openssl 命令的 -aes-256-cbc 解密选项来解密上面的字符串。**
|
||||||
|
|
||||||
# echo U2FsdGVkX18Zgoc+dfAdpIK58JbcEYFdJBPMINU91DKPeVVrU2k9oXWsgpvpdO/Z | openssl enc -aes-256-cbc -a -d -salt -pass pass:tecmint
|
# echo U2FsdGVkX18Zgoc+dfAdpIK58JbcEYFdJBPMINU91DKPeVVrU2k9oXWsgpvpdO/Z | openssl enc -aes-256-cbc -a -d -salt -pass pass:tecmint
|
||||||
|
|
||||||
![在 Linux 中解密字符串](http://www.tecmint.com/wp-content/uploads/2015/03/Decrypt-String-in-Linux.gif)
|
![在 Linux 中解密字符串](http://www.tecmint.com/wp-content/uploads/2015/03/Decrypt-String-in-Linux.gif)
|
||||||
在 Linux 中解密字符串
|
|
||||||
|
|
||||||
现在就是这些内容了。假如你知道任何这类的技巧,请将你的技巧发送到 admin@tecmint.com 邮箱中,你的技巧将会以你的名义来发表,同时我们也将在我们将来的文章中把它包含进去。
|
*在 Linux 中解密字符串*
|
||||||
|
|
||||||
|
现在就是这些内容了。
|
||||||
|
|
||||||
保持联系,保持连接,敬请关注。不要忘了在下面的评论中提供给我们您有价值的反馈。
|
保持联系,保持连接,敬请关注。不要忘了在下面的评论中提供给我们您有价值的反馈。
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
via: http://www.tecmint.com/generate-encrypt-decrypt-random-passwords-in-linux/
|
via: http://www.tecmint.com/generate-encrypt-decrypt-random-passwords-in-linux/
|
||||||
|
|
||||||
作者:[Avishek Kumar][a]
|
作者:[Avishek Kumar][a]
|
||||||
译者:[FSSlc](https://github.com/FSSlc)
|
译者:[FSSlc](https://github.com/FSSlc)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
[a]:http://www.tecmint.com/author/avishek/
|
[a]:http://www.tecmint.com/author/avishek/
|
||||||
[1]:http://www.tecmint.com/5-linux-command-line-tricks/
|
[1]:https://linux.cn/article-5485-1.html
|
||||||
[2]:http://www.tecmint.com/echo-command-in-linux/
|
[2]:http://linux.cn/article-3948-1.html
|
@ -1,29 +1,30 @@
|
|||||||
现在值得去尝试一下在CentOS 7.x或Fedora 21上面安装PHP 7.0
|
在CentOS 7.x / Fedora 21 上面体验 PHP 7.0
|
||||||
===============================================================================
|
===============================================================================
|
||||||
PHP是一种为我们熟知的通用的,服务器网页脚本语言。超大量的在线网站都是用PHP编写的。PHP过去一直在更新,丰富功能,易于使用,而且很好组织的脚本语言。目前PHP的开发团队正筹备下一个PHP版本的发行,名字是PHP 7。现在的PHP版本为PHP 5.6,可能你清楚PHP 6已经流产了,PHP 7的支持者们不希望下一个重要的版本被其他分支混淆,即过去已经停止很久的PHP 6。所以决定下一个PHP主要的发行版本叫PHP 7,而不是PHP 6。PHP 7.0预计在今年十一月份发行。
|
|
||||||
|
|
||||||
在下一个主要的PHP发行版里有一些不错的功能。
|
PHP是一种为我们熟知的通用服务器网页脚本语言。非常多的在线网站都是用PHP编写的。PHP这些年来一直在持续进化,丰富其功能,变得易于使用,更好地组织的脚本语言。目前PHP的开发团队正筹备下一个PHP版本的发行,名字是PHP 7。现在的PHP版本为PHP 5.6,可能你清楚PHP 6已经流产了,PHP 7的支持者们不希望下一个重要的版本被其他分支混淆,即过去已经停止很久的PHP 6。所以决定下一个PHP主要的发行版本叫PHP 7,而不是PHP 6。PHP 7.0预计在今年十一月份发行。
|
||||||
|
|
||||||
- 为了提升执行效率与记忆痕迹,PHPNG功能被添加到新的发行版中。
|
在下一代主要PHP版本里有一些不错的功能:
|
||||||
- JIT引擎被收入来动态编译Zend操作码为自然机器码,以此来达到更快的处理性能。这项功能允许随后的程序调用同一份代码,这样会运行快很多。
|
|
||||||
|
- 为了改善执行效率与内存占用,新的版本添加了PHPNG功能。
|
||||||
|
- 引入了JIT引擎来动态编译Zend操作码为自然机器码,以此来达到更快的处理性能。这项功能允许随后的程序调用同一份代码,这样会运行快很多。
|
||||||
- AST(抽象语法树)是最新添加的功能,它可以增强支持PHP的扩展性和用户应用。
|
- AST(抽象语法树)是最新添加的功能,它可以增强支持PHP的扩展性和用户应用。
|
||||||
- 异步编程功能会添加支持并行任务,在同样的需求下。
|
- 添加异步编程功能以支持同一个请求中的并行任务。
|
||||||
-新的版本会支持独立多线程网页服务,这样可以使用一个单独的存储块处理很多并发的请求。
|
- 新的版本会支持独立的多线程网页服务器,这样可以使用一个单独的存储池处理很多并发的请求。
|
||||||
|
|
||||||
### 在CcentOS/Fedora上安装PHP 7 ###
|
### 在CentOS/Fedora上安装PHP 7 ###
|
||||||
|
|
||||||
让我们来看看怎样在CentOS 7和Fedora 21安装PHP7。为了安装PHP7,我们首先需要克隆php-src 仓库。当克隆工作完成,我们会配置和编译它。进行下一步之前,我们要确保已经在LInux系统下安装了如下的东西,否则PHP编译会返回错误,然后流产。
|
让我们来看看怎样在CentOS 7和Fedora 21安装PHP7。为了安装PHP7,我们首先需要克隆php-src 仓库。当克隆工作完成,我们再配置和编译它。进行下一步之前,我们要确保已经在LInux系统下安装了如下的组件,否则PHP编译会返回错误中止。
|
||||||
|
|
||||||
- Git
|
- Git
|
||||||
- autoconf
|
- autoconf
|
||||||
- gcc
|
- gcc
|
||||||
- bison
|
- bison
|
||||||
|
|
||||||
所有上面提到的要求可以使用Yum软件包管理器安装。用连续的一个命令应该这样:
|
所有上面提到的要求可以使用Yum软件包管理器安装。以下一条命令即可完成:
|
||||||
|
|
||||||
yum install git autoconf gcc bison
|
yum install git autoconf gcc bison
|
||||||
|
|
||||||
准备好开始安装PHP7了吗?让我们先创建一个PHP7目录,作为你的工作目录。
|
准备好开始安装PHP7了吗?让我们先创建一个PHP7目录,作为你的当前工作目录。
|
||||||
|
|
||||||
mkdir php7
|
mkdir php7
|
||||||
|
|
||||||
@ -143,7 +144,7 @@ PHP是一种为我们熟知的通用的,服务器网页脚本语言。超大
|
|||||||
|
|
||||||
--with-mysqli=/usr/bin/mysql_config
|
--with-mysqli=/usr/bin/mysql_config
|
||||||
|
|
||||||
这会花去不少的时间,一旦完成,你应该会看到如下面的输出:
|
这会花去不少的时间,当完成后你应该会看到如下面的输出:
|
||||||
|
|
||||||
creating libtool
|
creating libtool
|
||||||
|
|
||||||
@ -206,9 +207,9 @@ PHP是一种为我们熟知的通用的,服务器网页脚本语言。超大
|
|||||||
|
|
||||||
运行下面的命令,完成编译过程。
|
运行下面的命令,完成编译过程。
|
||||||
|
|
||||||
manke
|
make
|
||||||
|
|
||||||
“make”命令过后的样例输出如下所示:
|
“make”命令的样例输出如下所示:
|
||||||
|
|
||||||
Generating phar.php
|
Generating phar.php
|
||||||
|
|
||||||
@ -294,7 +295,7 @@ PHP是一种为我们熟知的通用的,服务器网页脚本语言。超大
|
|||||||
|
|
||||||
cd sapi/cli
|
cd sapi/cli
|
||||||
|
|
||||||
在这里验证PHP的版本。
|
验证一下PHP的版本。
|
||||||
|
|
||||||
[root@localhost cli]# ./php -v
|
[root@localhost cli]# ./php -v
|
||||||
|
|
||||||
@ -306,7 +307,7 @@ PHP是一种为我们熟知的通用的,服务器网页脚本语言。超大
|
|||||||
|
|
||||||
### 总结 ###
|
### 总结 ###
|
||||||
|
|
||||||
PHP 7也被[添加到了remi仓库][1],即将到来的版本主要关注执行效率的提升,新的特性致力于使PHP较好满足现代编程的需求和趋势。PHP 7.0将会有许多新的特性,丢弃一些老版本的东西。在接下来的日子里,我们希望看到新特性和弃用功能的具体情况。尽情享受吧!
|
PHP 7也[添加到了remi仓库][1],这个即将到来的版本主要关注执行效率的提升,它的新特性致力于使PHP较好满足现代编程的需求和趋势。PHP 7.0将会有许多新的特性、丢弃一些老版本的东西。在接下来的日子里,我们希望看到新特性和弃用功能的具体情况。希望你喜欢!
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -314,7 +315,7 @@ via: http://linoxide.com/linux-how-to/install-php-7-centos-7-fedora-21/
|
|||||||
|
|
||||||
作者:[Aun Raza][a]
|
作者:[Aun Raza][a]
|
||||||
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,20 +1,21 @@
|
|||||||
Linux Email应用 Geary 更新了 — 如何在Ubuntu上安装
|
Linux Email应用 Geary 更新了
|
||||||
================================================================================
|
================================================================================
|
||||||
**Geary,Linux上流行的桌面email客户端,更新到版本0.10了 — 并且有了很多新的功能。**
|
**Geary,Linux上流行的桌面email客户端,更新到版本0.10了 — 并且有了很多新的功能。**
|
||||||
|
|
||||||
![elementary OS上运行的旧版本的Geary](http://www.omgubuntu.co.uk/wp-content/uploads/2015/01/geary.jpg)
|
![elementary OS上运行的旧版本的Geary](http://www.omgubuntu.co.uk/wp-content/uploads/2015/01/geary.jpg)
|
||||||
elementary OS上运行的旧版本的Geary
|
|
||||||
|
|
||||||
Geary 0.10有一些可惜的用户界面改进以及额外的UI选项,包括:
|
*elementary OS上运行的旧版本的Geary*
|
||||||
|
|
||||||
- 新增: 可以对归档,删除以及移动做'Undo'操作
|
Geary 0.10有一些不错的用户界面改进以及额外的UI功能,包括:
|
||||||
|
|
||||||
|
- 新增: 可以撤销归档、删除以及移动等操作
|
||||||
- 新增: 在2列或者2列布局之间切换
|
- 新增: 在2列或者2列布局之间切换
|
||||||
- 新的 “split header bar” — 改进邮件列表,发件人布局
|
- 新的 “split header bar” — 改进邮件列表,发件人布局
|
||||||
- 新的快捷键 — 使用j/k切换到上/下一封邮件
|
- 新的快捷键 — 使用j/k切换到上/下一封邮件
|
||||||
|
|
||||||
根据Yorba介绍,这次更新还提出了一个 **全新的全文检索算法** ,用来改进Geary的搜索体验。
|
根据Yorba介绍,这次更新还引入了一个**全新的全文检索算法** ,用来改进Geary的搜索体验。
|
||||||
|
|
||||||
这个更新应该能平息一下对应用搜索能力的抱怨,那些经常觉得Geary返回的搜索结果仅仅是包装软件自身"看起来和查询语句毫不相关"的观点。
|
这个更新应该能平息一下对该应用的搜索能力的抱怨:Geary返回的搜索结果就如同软件自己所宣称的“看起来和查询语句毫不相关”。
|
||||||
|
|
||||||
> ‘Yorba 建议所有这个软件客户端的用户升级到这个版本’
|
> ‘Yorba 建议所有这个软件客户端的用户升级到这个版本’
|
||||||
|
|
||||||
@ -36,7 +37,7 @@ Yorba的最新版本可以从GNOME的Git账户下载可编译的源代码。但
|
|||||||
|
|
||||||
Ubuntu用户想知道如何在 **14.04,14.10** 以及 **15.04**(那些更新爱好者) 上安装Geary 0.10。
|
Ubuntu用户想知道如何在 **14.04,14.10** 以及 **15.04**(那些更新爱好者) 上安装Geary 0.10。
|
||||||
|
|
||||||
官方的Youba PPA包括了 **Geary最新版本** 以及Shotwell(照片管理器)和[California][2](日历应用)。请注意添加这个PPA会使你电脑上任何已经安装的这些应用更新到最近的版本。
|
官方的Youba PPA包括了 **Geary 最新版本** 以及Shotwell(照片管理器)和[California][2](日历应用)。请注意添加这个PPA会使你电脑上任何已经安装的这些应用更新到最近的版本。
|
||||||
|
|
||||||
Capiche? Coolio.
|
Capiche? Coolio.
|
||||||
|
|
||||||
@ -52,7 +53,7 @@ Capiche? Coolio.
|
|||||||
|
|
||||||
完成后,打开你的桌面环境应用启动面板并查找‘Geary’图标。点击它,添加你的账户并查看[通过信息高速公路下载了什么][3],开始使用简单的图形界面吧。
|
完成后,打开你的桌面环境应用启动面板并查找‘Geary’图标。点击它,添加你的账户并查看[通过信息高速公路下载了什么][3],开始使用简单的图形界面吧。
|
||||||
|
|
||||||
**别忘记:你可以通过电子邮件告诉我们你想看的新闻,应用建议,以及任何你想我们包括的东西,直接点击joey@oho.io**
|
**别忘记:你可以通过电子邮件告诉我们你想看的新闻,应用建议,以及任何你想我们包括的东西。**
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -60,7 +61,7 @@ via: http://www.omgubuntu.co.uk/2015/03/install-geary-ubuntu-linux-email-update
|
|||||||
|
|
||||||
作者:[Joey-Elijah Sneddon][a]
|
作者:[Joey-Elijah Sneddon][a]
|
||||||
译者:[ictlyh](https://github.com/ictlyh)
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,9 +1,11 @@
|
|||||||
5个基于Linux命令行的文件下载和网站浏览工具
|
5 个基于Linux命令行的文件下载和网站浏览工具
|
||||||
================================================================================
|
================================================================================
|
||||||
GNU/Linux最冒险迷人的部分,Linux命令行,是非常强大的工具。命令行本身功能多样,多种内建或者第三方的命令行应用使得Linux变得更加健壮和强大。Linux Shell支持多种不同类型的网络应用,无论是BT下载软件,专用下载器或者互联网冲浪。
|
|
||||||
|
Linux命令行是GNU/Linux中最神奇迷人的部分,它是非常强大的工具。命令行本身功能多样,多种内建或者第三方的命令行应用使得Linux变得更加健壮和强大。Linux Shell支持多种不同类型的网络应用,无论是BT下载软件,专用下载器或者互联网冲浪。
|
||||||
|
|
||||||
![命令行互联网工具](http://www.tecmint.com/wp-content/uploads/2014/02/Command-Line-Internet-Tools.jpg)
|
![命令行互联网工具](http://www.tecmint.com/wp-content/uploads/2014/02/Command-Line-Internet-Tools.jpg)
|
||||||
5个命令行互联网工具
|
|
||||||
|
*5个命令行互联网工具*
|
||||||
|
|
||||||
这里我们介绍了5个很好的命令行互联网工具,它们非常有用,也很容易上手。
|
这里我们介绍了5个很好的命令行互联网工具,它们非常有用,也很容易上手。
|
||||||
|
|
||||||
@ -24,7 +26,8 @@ rTorrent是基于文本,用C++编写,追求高性能的Torrent客户端。
|
|||||||
# rtorrent
|
# rtorrent
|
||||||
|
|
||||||
![命令行torrent下载器](http://www.tecmint.com/wp-content/uploads/2014/02/rTorrent.jpeg)
|
![命令行torrent下载器](http://www.tecmint.com/wp-content/uploads/2014/02/rTorrent.jpeg)
|
||||||
rTorrent命令行工具
|
|
||||||
|
*rTorrent命令行工具*
|
||||||
|
|
||||||
#### rTorrent的功能 ####
|
#### rTorrent的功能 ####
|
||||||
|
|
||||||
@ -34,18 +37,18 @@ rTorrent命令行工具
|
|||||||
- CTRL+ s – 开始下载
|
- CTRL+ s – 开始下载
|
||||||
- CTRL+ d – 停止运行中的下载或者移除已完成的下载
|
- CTRL+ d – 停止运行中的下载或者移除已完成的下载
|
||||||
- CTRL+ k – 停止并关闭运行中的下载
|
- CTRL+ k – 停止并关闭运行中的下载
|
||||||
- CTRL+ r – 在上传/下载torrent之前进行Hash检查
|
- CTRL+ r – 在上传/下载种子之前进行Hash检查
|
||||||
- CTRL+ q – 执行两次这个命令,rTorrent会直接退出而不发送停止信号
|
- CTRL+ q – 执行两次这个命令,rTorrent会直接退出而不发送“停止”信号
|
||||||
- Left Arrow Key – 跳到上一屏幕
|
- Left Arrow Key – 跳到上一屏幕
|
||||||
- Right Arrow Key – 跳到下一屏幕
|
- Right Arrow Key – 跳到下一屏幕
|
||||||
|
|
||||||
### 2. Wget ###
|
### 2. Wget ###
|
||||||
|
|
||||||
Wget是GNU项目的一部分,名字由World Wide Web (WWW)衍生而来。Wget是用来递归下载,离线查看本地服务器HTML文件一个很好的工具,它可用于Windows, Max,以及Linux等大部分平台。Wget能通过HTTP,HTTPS和FTP下载文件。另外,能镜像整个网站,支持代理浏览以及暂停/回复下载使得它更为有用。
|
Wget是GNU项目的一部分,名字由World Wide Web (WWW)衍生而来。Wget是用来递归下载、离线查看本地服务器HTML文件一个很好的工具,它可用于Windows, Mac,以及Linux等大部分平台。Wget能通过HTTP,HTTPS和FTP下载文件。另外,能镜像整个网站,支持代理浏览以及暂停/回复下载使得它更为有用。
|
||||||
|
|
||||||
#### 安装Wget ####
|
#### 安装Wget ####
|
||||||
|
|
||||||
由于是GNE项目的一部分,Wget在大部分标准Linux发行版中都绑定发布,不再需要独立下载安装。如果默认没有安装,你也可以使用apt或者yum安装。
|
由于是GNU项目的一部分,Wget捆绑在大部分标准Linux发行版中,不再需要独立下载安装。如果默认没有安装,你也可以使用apt或者yum安装。
|
||||||
|
|
||||||
# apt-get install wget (基于 APT 的系统)
|
# apt-get install wget (基于 APT 的系统)
|
||||||
|
|
||||||
@ -70,13 +73,14 @@ Wget是GNU项目的一部分,名字由World Wide Web (WWW)衍生而来。Wget
|
|||||||
Wget是一个很棒的工具,它允许在资源有限的机器上自定义或者过滤下载。这是镜像一个网站(Yahoo.com)的wget下载截图。
|
Wget是一个很棒的工具,它允许在资源有限的机器上自定义或者过滤下载。这是镜像一个网站(Yahoo.com)的wget下载截图。
|
||||||
|
|
||||||
![Wget 下载文件](http://www.tecmint.com/wp-content/uploads/2014/02/Wget.jpeg)
|
![Wget 下载文件](http://www.tecmint.com/wp-content/uploads/2014/02/Wget.jpeg)
|
||||||
Wget 命令行文件下载
|
|
||||||
|
|
||||||
要获取更多wget下载的例子,可以阅读我们的文章[10个Wget下载命令例子][1]。
|
*Wget 命令行文件下载*
|
||||||
|
|
||||||
|
要获取更多wget下载的例子,可以阅读我们的文章[Wget下载命令例子][1]。
|
||||||
|
|
||||||
### 3. cURL ###
|
### 3. cURL ###
|
||||||
|
|
||||||
cURL是在多种协议上传输数据的命令行工具。cURL是支持FTP, HTTP, FTPS, TFTP, TELNET, IMAP, POP3等协议的客户端应用。和其它相对比,在支持LDAP,POP3方面,cURL是和wget不同的简单下载器。cURL也很好的支持代理下载,暂停下载以及恢复下载。
|
cURL是在多种协议上传输数据的命令行工具。cURL是支持FTP, HTTP, FTPS, TFTP, TELNET, IMAP, POP3等协议的客户端应用。cURL是一个不同于wget 的简单下载器,和其它的相比,它支持LDAP,POP3。cURL也很好的支持代理下载,暂停下载以及恢复下载。
|
||||||
|
|
||||||
#### 安装cURL ####
|
#### 安装cURL ####
|
||||||
|
|
||||||
@ -93,14 +97,16 @@ cURL的基本使用方法
|
|||||||
# curl www.tecmint.com
|
# curl www.tecmint.com
|
||||||
|
|
||||||
![Curl 下载](http://www.tecmint.com/wp-content/uploads/2014/02/Curl.jpeg)
|
![Curl 下载](http://www.tecmint.com/wp-content/uploads/2014/02/Curl.jpeg)
|
||||||
Curl 下载数据
|
|
||||||
|
*Curl 下载*
|
||||||
|
|
||||||
![Curl 下载数据](http://www.tecmint.com/wp-content/uploads/2014/02/Curl-2.jpeg)
|
![Curl 下载数据](http://www.tecmint.com/wp-content/uploads/2014/02/Curl-2.jpeg)
|
||||||
Curl 下载
|
|
||||||
|
*Curl 下载*
|
||||||
|
|
||||||
### 4. w3m ###
|
### 4. w3m ###
|
||||||
|
|
||||||
W3m是GPL协议下发布的基于文本的web浏览器。W3m支持表格,帧,颜色,SSL连接以及内联图像。W3m由于快速浏览而出名。
|
W3m是GPL协议下发布的基于文本的web浏览器。W3m支持表格,帧,颜色,SSL连接以及内联图像。W3m以快速浏览而出名。
|
||||||
|
|
||||||
#### 安装w3m ####
|
#### 安装w3m ####
|
||||||
|
|
||||||
@ -117,11 +123,12 @@ W3m在大部分Linux发行版中也是默认可用的。如果不可用的话可
|
|||||||
# w3m www.tecmint.com
|
# w3m www.tecmint.com
|
||||||
|
|
||||||
![命令行浏览器](http://www.tecmint.com/wp-content/uploads/2014/02/w3m.jpeg)
|
![命令行浏览器](http://www.tecmint.com/wp-content/uploads/2014/02/w3m.jpeg)
|
||||||
基于文本的web浏览器w3m
|
|
||||||
|
*基于文本的web浏览器w3m*
|
||||||
|
|
||||||
### 5. Elinks ###
|
### 5. Elinks ###
|
||||||
|
|
||||||
Elinks是基于文本,给基于Unix和基于Unix的系统使用的免费web浏览器。Elinks支持 HTTP,HTTP Cookies以及支持浏览Pery和Ruby脚本。也很好的支持基于标签的浏览。最棒的是它支持鼠标,颜色显示以及支持一系列的协议,例如HTTP, FTP, SMB, Ipv4 和 Ipv6。
|
Elinks是基于文本的免费浏览器,用于Unix及基于Unix的系统。Elinks支持 HTTP,HTTP Cookies以及支持浏览Perl和Ruby脚本(LCTT 译注:应该是指 CGI)。也很好的支持选项卡浏览。最棒的是它支持鼠标、彩色以及支持一系列的协议,例如HTTP, FTP, SMB, Ipv4 和 Ipv6。
|
||||||
|
|
||||||
#### 安装Elinks ####
|
#### 安装Elinks ####
|
||||||
|
|
||||||
@ -138,7 +145,8 @@ Elinks的基本使用方法
|
|||||||
# elinks www.tecmint.com
|
# elinks www.tecmint.com
|
||||||
|
|
||||||
![命令行互联网浏览](http://www.tecmint.com/wp-content/uploads/2014/02/Elinks.jpeg)
|
![命令行互联网浏览](http://www.tecmint.com/wp-content/uploads/2014/02/Elinks.jpeg)
|
||||||
Elinks命令行浏览互联网
|
|
||||||
|
*Elinks命令行浏览互联网*
|
||||||
|
|
||||||
就是这些了。有你们喜欢读的有趣的文章,我会再次来到这里。到那时尽请关注并保持和Tecmint的联系,别忘了在评论部分给我们你的宝贵的反馈。
|
就是这些了。有你们喜欢读的有趣的文章,我会再次来到这里。到那时尽请关注并保持和Tecmint的联系,别忘了在评论部分给我们你的宝贵的反馈。
|
||||||
|
|
||||||
@ -148,9 +156,9 @@ via: http://www.tecmint.com/linux-command-line-tools-for-downloading-files/
|
|||||||
|
|
||||||
作者:[Avishek Kumar][a]
|
作者:[Avishek Kumar][a]
|
||||||
译者:[ictlyh](https://github.com/ictlyh)
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
[a]:http://www.tecmint.com/author/avishek/
|
[a]:http://www.tecmint.com/author/avishek/
|
||||||
[1]:http://www.tecmint.com/10-wget-command-examples-in-linux/
|
[1]:https://linux.cn/article-4129-1.html
|
@ -1,62 +1,61 @@
|
|||||||
如何在CentOS上面安装CentOS网页面板
|
如何在CentOS上面安装“CentOS网页面板”
|
||||||
===========================================================================
|
===========================================================================
|
||||||
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/04/centos-790x427.jpg)
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/04/centos-790x427.jpg)
|
||||||
|
|
||||||
### 关于CentOS网页面板 ###
|
### 关于CentOS网页面板 ###
|
||||||
|
|
||||||
目前有很多免费的或者付费的控制面板。今天,我们来讨论[CentOS网页面板(CWP)][1],这是特别为基于如CentOS,RHEL,科研用Linux系统等发行版的RPM设计的。**CWP** 是免费且开源的控制面板,可以被广泛用于简单地配置一个网页集群环境。不同于其他的控制面板,CWP是自动用高速缓存来配置LAMP的栈区。
|
目前有很多免费的或者付费的控制面板。今天,我们来讨论[CentOS网页面板(CWP)][1],这是特别为基于RPM 的发行版,如CentOS,RHEL,Scientific Linux等设计的。**CWP** 是免费且开源的控制面板,可以被广泛用于简单地配置一个网页托管环境。不同于其他的控制面板,CWP能自动部署LAMP的软件栈及Varnish 缓存服务器。
|
||||||
|
|
||||||
### 特性 ###
|
### 特性 ###
|
||||||
|
|
||||||
CWP有很多的特性和免费的服务。如我前面提到的一样,CWP自动在你的服务器上安装全套LAMP服务(apache,php,phpmyadmin,webmail,mailserver等等)。
|
CWP有很多的特性和免费的服务。如我前面提到的一样,CWP会在你的服务器上自动安装全套的LAMP服务(apache,php,phpmyadmin,webmail,mailserver等等)。
|
||||||
|
|
||||||
### CWP安装过程中会安装和配置的软件列表 ###
|
### CWP安装过程中会安装和配置的软件列表 ###
|
||||||
|
|
||||||
- Apache Web Server
|
- Apache 网页服务器
|
||||||
- PHP 5.4
|
- PHP 5.4
|
||||||
- MySQL + phpMyAdmin
|
- MySQL + phpMyAdmin
|
||||||
- Postfix + Dovecot + roundcube webmail
|
- Postfix + Dovecot + roundcube webmail
|
||||||
- CSF Firewall
|
- CSF 防火墙
|
||||||
- File System Lock (no more website hacking, all your files are locked from changes)
|
- File System Lock (不需要修改网站,你的所有文件都会被锁定修改)
|
||||||
- Backups; AutoFixer for server configuration
|
- Backups; AutoFixer ,用于服务器配置
|
||||||
|
|
||||||
### 第三方应用: ###
|
### 第三方应用: ###
|
||||||
|
|
||||||
|
|
||||||
- CloudLinux + CageFS + PHP Selector
|
- CloudLinux + CageFS + PHP Selector
|
||||||
- Softaculous – Script Installer (Free and Premium)
|
- Softaculous – 脚本安装器 (免费版和白金版)
|
||||||
|
|
||||||
#### 网页服务器: ####
|
#### 网页服务器: ####
|
||||||
|
|
||||||
- Varnish Cache server
|
- Varnish 缓存服务器
|
||||||
- Compiles Apache from source
|
- 从代码编译 Apache
|
||||||
- Apache reCompiler + Additional modules
|
- Apache 重新编译+附加模块
|
||||||
- Apache server status, configuration
|
- Apache 服务器状态,配置
|
||||||
- Edit apache vhosts, vhosts templates, include configuration
|
- 编辑 Apache 虚拟主机、虚拟主机模版,包括配置
|
||||||
- Rebuild all apache Virtual hosts
|
- 重建所有 Apache 虚拟主机
|
||||||
- suPHP & suExec
|
- suPHP & suExec
|
||||||
- Mod Security + OWASP rules
|
- Mod Security + OWASP 规则
|
||||||
- Tomcat 8 server management
|
- Tomcat 8 服务器管理
|
||||||
- DoS protection
|
- DoS 防护
|
||||||
- Perl cgi script support
|
- Perl cgi 脚本支持
|
||||||
|
|
||||||
#### PHP: ####
|
#### PHP: ####
|
||||||
|
|
||||||
- PHP 切换器 (在PHP版本如: 5.2, 5.3, 5.4, 5.5之间切换)
|
- PHP 切换器 (在PHP版本如: 5.2、 5.3、 5.4、 5.5之间切换)
|
||||||
- PHP选择器选择每个用户或者每个文件的PHP版本(PHP 4.4, 5.2, 5.3, 5.4, 5.5, 5.6)
|
- PHP选择器,选择每个用户或者每个文件的PHP版本(PHP 4.4、 5.2、 5.3、 5.4、5.5、 5.6)
|
||||||
- 简单的php编辑软件
|
- 简单的php编辑器
|
||||||
- 在用户面板下简单的php.ini生成器
|
- 在用户面板下简单的php.ini生成器
|
||||||
- PHP 插件
|
- PHP 插件
|
||||||
- PHP.ini editor & PHP info & List modules
|
- PHP.ini 编辑器 & PHP 信息 和列出模块
|
||||||
- 每个帐号一个php.ini
|
- 每个帐号一个php.ini
|
||||||
- FFMPEG,用于视频流网站
|
- FFMPEG,用于视频流网站
|
||||||
- CloudLinux + PHP 选择器
|
- CloudLinux + PHP 选择器
|
||||||
|
|
||||||
#### 用户管理 ####
|
#### 用户管理 ####
|
||||||
|
|
||||||
- 添加,列举,编辑和移除用户
|
- 添加、列出、编辑和移除用户
|
||||||
- 用户监管
|
- 用户监管
|
||||||
- Shell接入管理
|
- Shell访问管理
|
||||||
- 用户限制管理
|
- 用户限制管理
|
||||||
- 限制进程
|
- 限制进程
|
||||||
- 限制访问文件
|
- 限制访问文件
|
||||||
@ -67,85 +66,85 @@ CWP有很多的特性和免费的服务。如我前面提到的一样,CWP自
|
|||||||
#### DNS: ####
|
#### DNS: ####
|
||||||
|
|
||||||
- FreeDNS
|
- FreeDNS
|
||||||
- 添加,编辑,列举和移除DNS区块
|
- 添加、编辑、列出和移除DNS区块
|
||||||
- 编辑域名服务的IP
|
- 编辑域名服务的IP
|
||||||
- DNS区块模板编辑器
|
- DNS区块模板编辑器
|
||||||
- 新的易用DNS区块管理器 (用ajax)
|
- 新的易用DNS区块管理器 (用ajax)
|
||||||
- 新的DNS区块列表,带有额外的修复信息 (同时检测 rDNS, 域名服务….)
|
- 新的DNS区块列表,带有额外的google解析信息 (同时检测 rDNS, 域名服务…)
|
||||||
|
|
||||||
#### Email: ####
|
#### Email: ####
|
||||||
|
|
||||||
- Postfix & dovecot
|
- Postfix & dovecot
|
||||||
- MailBoxes, Alias
|
- 邮箱、别名
|
||||||
- Roundcube webmail
|
- Roundcube webmail
|
||||||
- Postfix Mail queue
|
- Postfix 邮件队列
|
||||||
- rDNS Checker Module
|
- rDNS 检查器模块
|
||||||
- 垃圾邮件拦截
|
- 垃圾邮件拦截
|
||||||
- SPF & DKIM集成
|
- SPF & DKIM集成
|
||||||
- Re-Build Postfix/Dovecot Mail server with AntiVirus, AntiSpam Protection
|
- 重构带有反病毒、反垃圾邮件防护的 Postfix/Dovecot 的邮件服务器
|
||||||
- Email Auto Responder
|
- Email 自动应答器
|
||||||
|
|
||||||
#### 系统: ####
|
#### 系统: ####
|
||||||
|
|
||||||
- CPU核心和时钟信息
|
- CPU核心和时钟信息
|
||||||
- 内存使用信息
|
- 内存使用信息
|
||||||
- 详细的磁盘状态
|
- 详细的磁盘状态
|
||||||
- 软件信息如内核版本,正常运行时间等等.
|
- 软件信息如内核版本、正常运行时间等等.
|
||||||
- 服务器状态
|
- 服务器状态
|
||||||
- 检查配置管理
|
- ChkConfig管理
|
||||||
- 网络端口使用
|
- 网络端口使用
|
||||||
- 网络配置
|
- 网络配置
|
||||||
- SSHD配置
|
- sshd 配置
|
||||||
- 自动修复(检查重要的配置并尝试自动修复问题)
|
- 自动修复(检查重要的配置并尝试自动修复问题)
|
||||||
|
|
||||||
#### 监控: ####
|
#### 监控: ####
|
||||||
|
|
||||||
- 监控服务 eg. top, apache stats, mysql etc.
|
- 监控服务,例如 top、 apache 状态、 mysql 等
|
||||||
- 在面板内使用Java SSH Terminal/Console
|
- 在面板内使用Java SSH 终端/控制台
|
||||||
- 服务器配置 (eg. Apache, PHP, MySQL etc)
|
- 服务器配置 (例如 Apache、 PHP、 MySQL 等)
|
||||||
- 在屏幕/后台运行命令行
|
- 在屏幕/后台运行命令行
|
||||||
|
|
||||||
#### 安全: ####
|
#### 安全: ####
|
||||||
|
|
||||||
- CSF防火墙
|
- CSF防火墙
|
||||||
- SSL产生器
|
- SSL生成器
|
||||||
- SSL证书管理
|
- SSL证书管理
|
||||||
- CloudLinux + CageFS
|
- CloudLinux + CageFS
|
||||||
|
|
||||||
#### SQL: ####
|
#### SQL: ####
|
||||||
|
|
||||||
- MySQL 数据库管理
|
- MySQL 数据库管理
|
||||||
- 添加本地或者远程接入用户
|
- 添加本地或者远程访问的用户
|
||||||
- 实时监控MySQL进程列表
|
- 实时监控MySQL进程列表
|
||||||
- 创建,移除数据库
|
- 创建,移除数据库
|
||||||
- 为每个数据库添加额外的用户
|
- 为每个数据库添加额外的用户
|
||||||
- MySQL服务器配置
|
- MySQL服务器配置
|
||||||
- PhpMyAdmin(这个不知道要不要译过来)
|
- PhpMyAdmin
|
||||||
- PostgreSQL, phpPgAdmin支持
|
- PostgreSQL, phpPgAdmin支持
|
||||||
|
|
||||||
#### 额外功能: ####
|
#### 额外功能: ####
|
||||||
|
|
||||||
- 语言通话3 管理
|
- TeamSpeak 3 管理器
|
||||||
- 网络电台管理
|
- Shoutcast 管理器
|
||||||
- 自动更新
|
- 自动更新
|
||||||
- 备份管理
|
- 备份管理器
|
||||||
- 文件管理
|
- 文件管理器
|
||||||
- 每个域名的虚拟FTP用户
|
- 每个域名的虚拟FTP用户
|
||||||
- 控制面板帐号移植 (恢复文件,数据库和数据库用户)
|
- cPanel帐号迁移 (恢复文件,数据库和数据库用户)
|
||||||
- 还有更多.
|
- 还有更多
|
||||||
|
|
||||||
### 在CentOS 6上安装CentOS网页面板 ###
|
### 在CentOS 6上安装CentOS网页面板 ###
|
||||||
|
|
||||||
写这篇教程的时候,CWP仅仅支持最高CentOS 6.x版本。在CentOS 7和更高的版本中是行不通的。
|
写这篇教程的时候,CWP仅仅支持最高CentOS 6.x版本。在CentOS 7和更高的版本中是不支持的。
|
||||||
|
|
||||||
#### 前期准备: ####
|
#### 前期准备: ####
|
||||||
|
|
||||||
**安装CWP之前,里必须知道以下的信息:**
|
**安装CWP之前,你必须知道以下的信息:**
|
||||||
|
|
||||||
- CWP 仅支持静态IP地址。它并不支持动态的,固定的,或者内部的IP地址。
|
- CWP 仅支持静态IP地址。它并不支持动态的,或者内部的IP地址。
|
||||||
- CWP 并没有卸载程序。当你安装CWP后,里必须重新安装服务器来移除它。
|
- CWP 并没有卸载程序。当你安装CWP后,你必须重新安装服务器来移除它。
|
||||||
- 之安装CWP在一个新装的还没做任何配置改变的操作系统上。
|
- 只能在一个新装的还没做任何配置改变的操作系统上安装CWP。
|
||||||
- 对与32位操作系统至少需要512MB RAM。
|
- 对于32位操作系统至少需要512MB RAM。
|
||||||
- 64位系统需要1024MB RAM。
|
- 64位系统需要1024MB RAM。
|
||||||
- 要求至少20GB的硬盘空间。
|
- 要求至少20GB的硬盘空间。
|
||||||
|
|
||||||
@ -175,7 +174,7 @@ CWP有很多的特性和免费的服务。如我前面提到的一样,CWP自
|
|||||||
|
|
||||||
如果上面的URL出现错误,用下面的链接代替。
|
如果上面的URL出现错误,用下面的链接代替。
|
||||||
|
|
||||||
wget http://dll.centos-webpanle.com/files/cwp-latest
|
wget http://dl1.centos-webpanle.com/files/cwp-latest
|
||||||
|
|
||||||
然后,用命令开始安装CWP:
|
然后,用命令开始安装CWP:
|
||||||
|
|
||||||
@ -189,8 +188,7 @@ CWP有很多的特性和免费的服务。如我前面提到的一样,CWP自
|
|||||||
|
|
||||||
安装过程会持续到30分钟或者更多,取决于你的网速。
|
安装过程会持续到30分钟或者更多,取决于你的网速。
|
||||||
|
|
||||||
最后,你会看到如下安装完成的信息。
|
最后,你会看到如下安装完成的信息。记下一些详细信息,如mysql超级用户密码和CWP的登录URL,你随后会需要它们。然后,按下回车Enter重启系统。
|
||||||
记下一些详细信息,如mysql超级用户密码和CWP的登录URLs。你随后会需要。然后,按下回车Enter重启系统。
|
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/root@server-usr-local-src_004.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/root@server-usr-local-src_004.png)
|
||||||
|
|
||||||
@ -200,7 +198,7 @@ CWP有很多的特性和免费的服务。如我前面提到的一样,CWP自
|
|||||||
|
|
||||||
#### 调整防火墙/路由: ####
|
#### 调整防火墙/路由: ####
|
||||||
|
|
||||||
CWP的默认网络控制接口是**2030(http)**和**2031(https)**。你应该通过防火墙/路由允许使用这两个端口,以便远程接入CWP网络控制台。
|
CWP的默认网页控制界面的端口是**2030(http)**和**2031(https)**。你应该通过防火墙/路由允许使用这两个端口,以便远程接入CWP网络控制台。
|
||||||
|
|
||||||
编辑iptables文件:
|
编辑iptables文件:
|
||||||
|
|
||||||
@ -242,43 +240,42 @@ CWP的默认网络控制接口是**2030(http)**和**2031(https)**。你
|
|||||||
|
|
||||||
接下来,我们得做一些事,比如:
|
接下来,我们得做一些事,比如:
|
||||||
|
|
||||||
1.建立域名服务
|
1. 设置域名服务器
|
||||||
1.建立ip共享(必须是你的公共IP地址)
|
1. 设置 ip 共享(必须是你的公共IP地址)
|
||||||
1.建立至少一个集合包(或者编辑默认的包)
|
1. 设置至少一个托管包(或者编辑默认的包)
|
||||||
1.建立root电子邮件,等等。
|
1. 设置 root 电子邮件,等等。
|
||||||
|
|
||||||
#### 建立域名服务: ####
|
#### 设置域名服务器: ####
|
||||||
|
|
||||||
为建立域名服务,找到**DNS Functions -> Edit nameservers IPs**。
|
为建立域名服务器,找到**DNS Functions -> Edit nameservers IPs**。
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_009.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_009.png)
|
||||||
|
|
||||||
设置你的域名服务器,点击保存按钮。
|
设置你的域名服务器,点击保存按钮。
|
||||||
|
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_010.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_010.png)
|
||||||
|
|
||||||
#### 建立共享IP和Root邮箱ID: ####
|
#### 建立共享IP和Root邮件地址: ####
|
||||||
|
|
||||||
在你的主机上管理网站,这是非常重要的一步。为了建立共享IP,进入**CWP Setting -> Edit settings**。
|
在你的主机上托管网站,这是非常重要的一步。为了建立共享IP,进入**CWP Setting -> Edit settings**。
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_011.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_011.png)
|
||||||
|
|
||||||
输入你的静态IP和邮箱ID,然后点击保存设置按钮。
|
输入你的静态IP和邮件地址,然后点击保存设置按钮。
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_012.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_012.png)
|
||||||
|
|
||||||
现在,CWP可以进行网站维护了。
|
现在,CWP可以进行网站维护了。
|
||||||
|
|
||||||
#### 建立主机包 ####
|
#### 建立托管包 ####
|
||||||
|
|
||||||
一个主机包什么都没有,除了一个网站托管计划,包括允许访问的磁盘空间,带宽,但没有FTP帐号,邮箱IDs和数据库等等。你可以建立任意数量的网站托管计划,只要你喜欢。
|
一个托管包就是一个网站托管计划,包括允许访问的磁盘空间,带宽,但没有FTP帐号,邮箱地址和数据库等等。你可以建立任意数量的网站托管计划,只要你喜欢。
|
||||||
|
|
||||||
添加一个包,从CWP的控制台进入**Packages — Add a Package**
|
要添加一个包,从CWP的控制台进入**Packages — Add a Package**
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_013.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_013.png)
|
||||||
|
|
||||||
输入包的名字,允许访问的磁盘配额/RAM数量,FTP/Email帐号,数据库和子域名等等。点击保持设置按钮,建立一个网站托管计划。
|
输入包的名字,允许访问的磁盘配额/RAM数量,FTP/Email帐号,数据库和子域名等等。点击保存设置按钮,建立一个网站托管计划。
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_014.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_014.png)
|
||||||
|
|
||||||
@ -290,7 +287,7 @@ CWP的默认网络控制接口是**2030(http)**和**2031(https)**。你
|
|||||||
|
|
||||||
而添加一个用户,请进入**User Account -> New Account**。
|
而添加一个用户,请进入**User Account -> New Account**。
|
||||||
|
|
||||||
输入域名(ex.unixmen.com),用户名,密码和邮箱id等等。最后,点击**Create**。
|
输入域名(ex.unixmen.com),用户名,密码和邮箱地址等等。最后,点击**Create**。
|
||||||
|
|
||||||
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_016.png)
|
![](http://www.unixmen.com/wp-content/uploads/2015/04/CWP.admin-Mozilla-Firefox_016.png)
|
||||||
|
|
||||||
@ -312,12 +309,11 @@ CWP的默认网络控制接口是**2030(http)**和**2031(https)**。你
|
|||||||
|
|
||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
via: http://www.unixmen.com/how-to-install-centos-web-panel-in-centos/
|
via: http://www.unixmen.com/how-to-install-centos-web-panel-in-centos/
|
||||||
|
|
||||||
作者:[SK][a]
|
作者:[SK][a]
|
||||||
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,86 @@
|
|||||||
|
Quagga上使用验证加固BGP会话安全
|
||||||
|
================================================================================
|
||||||
|
BGP协议运行于TCP之上,因而,它也继承了TCP连接的所有漏洞。例如,在一个BGP会话内,攻击者可以冒充一个合法的BGP邻居,然后说服另一端的BGP路由器共享路由信息给攻击者。在攻击者通告并向邻居路由注入伪造的路由时,就会发生这个问题。毫无戒备的邻居路由器就会开始向攻击者发送通信实况,实际上这些信息并没有去向任何地方,仅仅只是被丢弃了。回到2008年,YouTube实际上也[受害于][1]这样的BGP路由中毒,并遭受了长达一个小时的视频服务大量中断。一个更加糟糕的情况是,如果攻击者是个足够懂行的人,他们可以伪装成一台透明路由器,然后嗅探经过的通信以获取敏感数据。你可以想象,这会造成深远的影响。
|
||||||
|
|
||||||
|
要保护活跃的BGP会话不受攻击,许多服务提供商在BGP会话中使用[MD5校验和及预共享密钥][2]。在受保护的BGP会话中,一台发送包的BGP路由器通过使用预共享的密钥生成MD5散列值、部分IP和TCP头以及有效载荷。然后,MD5散列作为一个TCP选项字段存储。在收到包后,接受路由器用同样的方法使用预共享密钥生成它的MD5版本。它会将它的MD5散列和接收到的某个包的值进行对比,以决定是否接受该包。对于一个攻击者而言,几乎不可能猜测到校验和或其密钥。对于BGP路由器而言,它们能在使用包的内容前确保每个包的合法性。
|
||||||
|
|
||||||
|
在本教程中,我们将为大家演示如何使用MD5校验和以及预共享密钥来加固两个邻居间的BGP会话的安全。
|
||||||
|
|
||||||
|
### 准备 ###
|
||||||
|
|
||||||
|
加固BGP会话安全是相当简单而直截了当的,我们会使用以下路由器。
|
||||||
|
|
||||||
|
<table id="content">
|
||||||
|
<tbody><tr>
|
||||||
|
<td><b>路由器名称</b></td>
|
||||||
|
<td><b>AS 号</b></td>
|
||||||
|
<td><b>IP地址</b></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>router-A</td>
|
||||||
|
<td>100</td>
|
||||||
|
<td>10.10.12.1/30</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>router-B</td>
|
||||||
|
<td>200</td>
|
||||||
|
<td>10.10.12.2/30</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
|
||||||
|
常用的Linux内核原生支持IPv4和IPv6的TCP MD5选项。因此,如果你从全新的[Linux机器][3]构建了一台Quagga路由器,TCP的MD5功能会自动启用。剩下来的事情,仅仅是配置Quagga以使用它的功能。但是,如果你使用的是FreeBSD机器或者为Quagga构建了一个自定义内核,请确保内核开启了TCP的MD5支持(如,Linux中的CONFIG_TCP_MD5SIG选项)。
|
||||||
|
|
||||||
|
### 配置Router-A验证功能 ###
|
||||||
|
|
||||||
|
我们将使用Quagga的CLI Shell来配置路由器,我们将使用的唯一的一个新命令是‘password’。
|
||||||
|
|
||||||
|
[root@router-a ~]# vtysh
|
||||||
|
router-a# conf t
|
||||||
|
router-a(config)# router bgp 100
|
||||||
|
router-a(config-router)# network 192.168.100.0/24
|
||||||
|
router-a(config-router)# neighbor 10.10.12.2 remote-as 200
|
||||||
|
router-a(config-router)# neighbor 10.10.12.2 password xmodulo
|
||||||
|
|
||||||
|
本例中使用的预共享密钥是‘xmodulo’。很明显,在生产环境中,你需要选择一个更健壮的密钥。
|
||||||
|
|
||||||
|
**注意**: 在Quagga中,‘service password-encryption’命令被用做加密配置文件中所有明文密码(如,登录密码)。然而,当我使用该命令时,我注意到BGP配置中的预共享密钥仍然是明文的。我不确定这是否是Quagga的限制,还是版本自身的问题。
|
||||||
|
|
||||||
|
### 配置Router-B验证功能 ###
|
||||||
|
|
||||||
|
我们将以类似的方式配置router-B。
|
||||||
|
|
||||||
|
[root@router-b ~]# vtysh
|
||||||
|
router-b# conf t
|
||||||
|
router-b(config)# router bgp 200
|
||||||
|
router-b(config-router)# network 192.168.200.0/24
|
||||||
|
router-b(config-router)# neighbor 10.10.12.1 remote-as 100
|
||||||
|
router-b(config-router)# neighbor 10.10.12.1 password xmodulo
|
||||||
|
|
||||||
|
### 验证BGP会话 ###
|
||||||
|
|
||||||
|
如果一切配置正确,那么BGP会话就应该起来了,两台路由器应该能交换路由表。这时候,TCP会话中的所有流出包都会携带一个MD5摘要的包内容和一个密钥,而摘要信息会被另一端自动验证。
|
||||||
|
|
||||||
|
我们可以像平时一样通过查看BGP的概要来验证活跃的BGP会话。MD5校验和的验证在Quagga内部是透明的,因此,你在BGP级别是无法看到的。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7621/16837774368_e9ff66b370_c.jpg)
|
||||||
|
|
||||||
|
如果你想要测试BGP验证,你可以配置一个邻居路由,设置其密码为空,或者故意使用错误的预共享密钥,然后查看发生了什么。你也可以使用包嗅探器,像tcpdump或者Wireshark等,来分析通过BGP会话的包。例如,带有“-M <secret>”选项的tcpdump将验证TCP选项字段的MD5摘要。
|
||||||
|
|
||||||
|
###小结###
|
||||||
|
|
||||||
|
在本教程中,我们演示了怎样简单地加固两台路由间的BGP会话安全。相对于其它协议而言,配置过程非常简明。强烈推荐你加固BGP会话安全,尤其是当你用另一个AS配置BGP会话的时候。预共享密钥也应该安全地保存。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/bgp-authentication-quagga.html
|
||||||
|
|
||||||
|
作者:[Sarmed Rahman][a]
|
||||||
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/sarmed
|
||||||
|
[1]:http://research.dyn.com/2008/02/pakistan-hijacks-youtube-1/
|
||||||
|
[2]:http://tools.ietf.org/html/rfc2385
|
||||||
|
[3]:https://linux.cn/article-4232-1.html
|
@ -0,0 +1,261 @@
|
|||||||
|
4个可以发送完整电子邮件的命令行工具
|
||||||
|
================================================================================
|
||||||
|
今天的文章里我们会讲到一些使用Linux命令行工具来发送带附件的电子邮件的方法。它有很多用处,比如在应用程序所在服务器上,使用电子邮件发送一个文件过来,或者你可以在脚本中使用这些命令来做一些自动化操作。在本文的例子中,我们会使用foo.tar.gz文件作为附件。
|
||||||
|
|
||||||
|
有不同的命令行工具可以发送邮件,这里我分享几个多数用户会使用的工具,如`mailx`、`mutt`和`swaks`。
|
||||||
|
|
||||||
|
我们即将呈现的这些工具都是非常有名的,并且存在于多数Linux发行版默认的软件仓库中,你可以使用如下命令安装:
|
||||||
|
|
||||||
|
在 **Debian / Ubuntu** 系统
|
||||||
|
|
||||||
|
apt-get install mutt
|
||||||
|
apt-get install swaks
|
||||||
|
apt-get install mailx
|
||||||
|
apt-get install sharutils
|
||||||
|
|
||||||
|
在基于Red Hat的系统,如 **CentOS** 或者 **Fedora**
|
||||||
|
|
||||||
|
yum install mutt
|
||||||
|
yum install swaks
|
||||||
|
yum install mailx
|
||||||
|
yum install sharutils
|
||||||
|
|
||||||
|
### 1) 使用 mail / mailx ###
|
||||||
|
|
||||||
|
`mailx`工具在多数Linux发行版中是默认的邮件程序,现在已经支持发送附件了。如果它不在你的系统中,你可以使用上边的命令安装。有一点需要注意,老版本的mailx可能不支持发送附件,运行如下命令查看是否支持。
|
||||||
|
|
||||||
|
$ man mail
|
||||||
|
|
||||||
|
第一行看起来是这样的:
|
||||||
|
|
||||||
|
mailx [-BDdEFintv~] [-s subject] [-a attachment ] [-c cc-addr] [-b bcc-addr] [-r from-addr] [-h hops] [-A account] [-S variable[=value]] to-addr . . .
|
||||||
|
|
||||||
|
如果你看到它支持`-a`的选项(-a 文件名,将文件作为附件添加到邮件)和`-s`选项(-s 主题,指定邮件的主题),那就是支持的。可以使用如下的几个例子发送邮件。
|
||||||
|
|
||||||
|
**a) 简单的邮件**
|
||||||
|
|
||||||
|
运行`mail`命令,然后`mailx`会等待你输入邮件内容。你可以按回车来换行。当输入完成后,按Ctrl + D,`mailx`会显示EOT表示结束。
|
||||||
|
|
||||||
|
然后`mailx`会自动将邮件发送给收件人。
|
||||||
|
|
||||||
|
$ mail user@example.com
|
||||||
|
|
||||||
|
HI,
|
||||||
|
Good Morning
|
||||||
|
How are you
|
||||||
|
EOT
|
||||||
|
|
||||||
|
**b) 发送有主题的邮件**
|
||||||
|
|
||||||
|
$ echo "Email text" | mail -s "Test Subject" user@example.com
|
||||||
|
|
||||||
|
`-s`的用处是指定邮件的主题。
|
||||||
|
|
||||||
|
**c) 从文件中读取邮件内容并发送**
|
||||||
|
|
||||||
|
$ mail -s "message send from file" user@example.com < /path/to/file
|
||||||
|
|
||||||
|
**d) 将从管道获取到的`echo`命令输出作为邮件内容发送**
|
||||||
|
|
||||||
|
$ echo "This is message body" | mail -s "This is Subject" user@example.com
|
||||||
|
|
||||||
|
**e) 发送带附件的邮件**
|
||||||
|
|
||||||
|
$ echo “Body with attachment "| mail -a foo.tar.gz -s "attached file" user@example.com
|
||||||
|
|
||||||
|
`-a`选项用于指定附件。
|
||||||
|
|
||||||
|
### 2) mutt ###
|
||||||
|
|
||||||
|
Mutt是类Unix系统上的一个文本界面邮件客户端。它有20多年的历史,在Linux历史中也是一个很重要的部分,它是最早支持进程打分和多线程处理的客户端程序之一。按照如下的例子来发送邮件。
|
||||||
|
|
||||||
|
**a) 带有主题,从文件中读取邮件的正文,并发送**
|
||||||
|
|
||||||
|
$ mutt -s "Testing from mutt" user@example.com < /tmp/message.txt
|
||||||
|
|
||||||
|
**b) 通过管道获取`echo`命令输出作为邮件内容发送**
|
||||||
|
|
||||||
|
$ echo "This is the body" | mutt -s "Testing mutt" user@example.com
|
||||||
|
|
||||||
|
**c) 发送带附件的邮件**
|
||||||
|
|
||||||
|
$ echo "This is the body" | mutt -s "Testing mutt" user@example.com -a /tmp/foo.tar.gz
|
||||||
|
|
||||||
|
**d) 发送带有多个附件的邮件**
|
||||||
|
|
||||||
|
$ echo "This is the body" | mutt -s "Testing" user@example.com -a foo.tar.gz –a bar.tar.gz
|
||||||
|
|
||||||
|
### 3) swaks ###
|
||||||
|
|
||||||
|
Swaks(Swiss Army Knife,瑞士军刀)是SMTP服务上的瑞士军刀,它是一个功能强大、灵活、可编程、面向事务的SMTP测试工具,由John Jetmore开发和维护。你可以使用如下语法发送带附件的邮件:
|
||||||
|
|
||||||
|
$ swaks -t "foo@bar.com" --header "Subject: Subject" --body "Email Text" --attach foo.tar.gz
|
||||||
|
|
||||||
|
关于Swaks一个重要的地方是,它会为你显示整个邮件发送过程,所以如果你想调试邮件发送过程,它是一个非常有用的工具。
|
||||||
|
|
||||||
|
它会给你提供了邮件发送过程的所有细节,包括邮件接收服务器的功能支持、两个服务器之间的每一步交互。
|
||||||
|
|
||||||
|
### 4) uuencode ###
|
||||||
|
|
||||||
|
邮件传输系统最初是被设计来传送7位编码(类似ASCII)的内容的。这就意味这它是用来发送文本内容,而不能发会使用8位的二进制内容(如程序文件或者图片)。`uuencode`(“UNIX to UNIX encoding”,UNIX之间使用的编码方式)程序用来解决这个限制。使用`uuencode`,发送端将二进制格式的转换成文本格式来传输,接收端再转换回去。
|
||||||
|
|
||||||
|
我们可以简单地使用`uuencode`和`mailx`或者`mutt`配合,来发送二进制内容,类似这样:
|
||||||
|
|
||||||
|
$ uuencode example.jpeg example.jpeg | mail user@example.com
|
||||||
|
|
||||||
|
### Shell脚本:解释如何发送邮件 ###
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
FROM=""
|
||||||
|
SUBJECT=""
|
||||||
|
ATTACHMENTS=""
|
||||||
|
TO=""
|
||||||
|
BODY=""
|
||||||
|
|
||||||
|
# 检查文件名对应的文件是否存在
|
||||||
|
function check_files()
|
||||||
|
{
|
||||||
|
output_files=""
|
||||||
|
for file in $1
|
||||||
|
do
|
||||||
|
if [ -s $file ]
|
||||||
|
then
|
||||||
|
output_files="${output_files}${file} "
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo $output_files
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "*********************"
|
||||||
|
echo "E-mail sending script."
|
||||||
|
echo "*********************"
|
||||||
|
echo
|
||||||
|
|
||||||
|
# 读取用户输入的邮件地址
|
||||||
|
while [ 1 ]
|
||||||
|
do
|
||||||
|
if [ ! $FROM ]
|
||||||
|
then
|
||||||
|
echo -n -e "Enter the e-mail address you wish to send mail from:\n[Enter] "
|
||||||
|
else
|
||||||
|
echo -n -e "The address you provided is not valid:\n[Enter] "
|
||||||
|
fi
|
||||||
|
|
||||||
|
read FROM
|
||||||
|
echo $FROM | grep -E '^.+@.+$' > /dev/null
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
# 读取用户输入的收件人地址
|
||||||
|
while [ 1 ]
|
||||||
|
do
|
||||||
|
if [ ! $TO ]
|
||||||
|
then
|
||||||
|
echo -n -e "Enter the e-mail address you wish to send mail to:\n[Enter] "
|
||||||
|
else
|
||||||
|
echo -n -e "The address you provided is not valid:\n[Enter] "
|
||||||
|
fi
|
||||||
|
|
||||||
|
read TO
|
||||||
|
echo $TO | grep -E '^.+@.+$' > /dev/null
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
# 读取用户输入的邮件主题
|
||||||
|
echo -n -e "Enter e-mail subject:\n[Enter] "
|
||||||
|
read SUBJECT
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
if [ "$SUBJECT" == "" ]
|
||||||
|
then
|
||||||
|
echo "Proceeding without the subject..."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 读取作为附件的文件名
|
||||||
|
echo -e "Provide the list of attachments. Separate names by space.
|
||||||
|
If there are spaces in file name, quote file name with \"."
|
||||||
|
read att
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
# 确保文件名指向真实文件
|
||||||
|
attachments=$(check_files "$att")
|
||||||
|
echo "Attachments: $attachments"
|
||||||
|
|
||||||
|
for attachment in $attachments
|
||||||
|
do
|
||||||
|
ATTACHMENTS="$ATTACHMENTS-a $attachment "
|
||||||
|
done
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
# 读取完整的邮件正文
|
||||||
|
echo "Enter message. To mark the end of message type ;; in new line."
|
||||||
|
read line
|
||||||
|
|
||||||
|
while [ "$line" != ";;" ]
|
||||||
|
do
|
||||||
|
BODY="$BODY$line\n"
|
||||||
|
read line
|
||||||
|
done
|
||||||
|
|
||||||
|
SENDMAILCMD="mutt -e \"set from=$FROM\" -s \"$SUBJECT\" \
|
||||||
|
$ATTACHMENTS -- \"$TO\" <<< \"$BODY\""
|
||||||
|
echo $SENDMAILCMD
|
||||||
|
|
||||||
|
mutt -e "set from=$FROM" -s "$SUBJECT" $ATTACHMENTS -- $TO <<< $BODY
|
||||||
|
|
||||||
|
** 脚本输出 **
|
||||||
|
|
||||||
|
$ bash send_mail.sh
|
||||||
|
*********************
|
||||||
|
E-mail sending script.
|
||||||
|
*********************
|
||||||
|
|
||||||
|
Enter the e-mail address you wish to send mail from:
|
||||||
|
[Enter] test@gmail.com
|
||||||
|
|
||||||
|
Enter the e-mail address you wish to send mail to:
|
||||||
|
[Enter] test@gmail.com
|
||||||
|
|
||||||
|
Enter e-mail subject:
|
||||||
|
[Enter] Message subject
|
||||||
|
|
||||||
|
Provide the list of attachments. Separate names by space.
|
||||||
|
If there are spaces in file name, quote file name with ".
|
||||||
|
send_mail.sh
|
||||||
|
|
||||||
|
Attachments: send_mail.sh
|
||||||
|
|
||||||
|
Enter message. To mark the end of message type ;; in new line.
|
||||||
|
This is a message
|
||||||
|
text
|
||||||
|
;;
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
有很多方法可以使用命令行/Shell脚本来发送邮件,这里我们只分享了其中4个类Unix系统可用的工具。希望你喜欢我们的文章,并且提供您的宝贵意见,让我们知道您想了解哪些新工具。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://linoxide.com/linux-shell-script/send-email-subject-body-attachment-linux/
|
||||||
|
|
||||||
|
作者:[Bobbin Zachariah][a]
|
||||||
|
译者:[goreliu](https://github.com/goreliu)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://linoxide.com/author/bobbin/
|
@ -1,8 +1,8 @@
|
|||||||
安装Inkscape - 开源适量图形编辑器
|
Inkscape - 开源适量图形编辑器
|
||||||
================================================================================
|
================================================================================
|
||||||
Inkscape是一款开源矢量图形编辑工具,它使用可缩放矢量图形(SVG)图形格式并不同于它的竞争对手如Xara X、Corel Draw和Adobe Illustrator等等。SVG是一个广泛部署、免版税使用的图形格式,由W3C SVG工作组开发和维护。这是一个跨平台工具,完美运行于Linux、Windows和Mac OS上。
|
Inkscape是一款开源矢量图形编辑工具,并不同于Xara X、Corel Draw和Adobe Illustrator等竞争对手,它使用的是可缩放矢量图形(SVG)图形格式。SVG是一个广泛部署、免版税使用的图形格式,由W3C SVG工作组开发和维护。这是一个跨平台工具,完美运行于Linux、Windows和Mac OS上。
|
||||||
|
|
||||||
Inkscape始于2003年,起初它的bug跟踪系统托管于Sourceforge上但是 后来迁移到了Launchpad上。当前它最新的一个稳定版本是0.91,它不断地在发展和修改中。我们将在本文里了解一下它的突出特点和安装过程。
|
Inkscape始于2003年,起初它的bug跟踪系统托管于Sourceforge上,但是后来迁移到了Launchpad上。当前它最新的一个稳定版本是0.91,它不断地在发展和修改中。我们将在本文里了解一下它的突出特点和安装过程。
|
||||||
|
|
||||||
### 显著特性 ###
|
### 显著特性 ###
|
||||||
|
|
||||||
@ -12,30 +12,30 @@ Inkscape始于2003年,起初它的bug跟踪系统托管于Sourceforge上但是
|
|||||||
|
|
||||||
- 用铅笔工具来画出不同颜色、大小和形状的手绘线,用贝塞尔曲线(笔式)工具来画出直线和曲线,通过书法工具来应用到手写的书法笔画上等等
|
- 用铅笔工具来画出不同颜色、大小和形状的手绘线,用贝塞尔曲线(笔式)工具来画出直线和曲线,通过书法工具来应用到手写的书法笔画上等等
|
||||||
- 用文本工具来创建、选择、编辑和格式化文本。在纯文本框、在路径上或在形状里操作文本
|
- 用文本工具来创建、选择、编辑和格式化文本。在纯文本框、在路径上或在形状里操作文本
|
||||||
- 有效绘制各种形状,像矩形、椭圆形、圆形、弧线、多边形、星形和螺旋形等等并调整其大小、旋转并修改(圆角化)它们
|
- 方便绘制各种形状,像矩形、椭圆形、圆形、弧线、多边形、星形和螺旋形等等并调整其大小、旋转并修改(圆角化)它们
|
||||||
- 用简单地命令创建并嵌入位图
|
- 用简单地命令创建并嵌入位图
|
||||||
|
|
||||||
#### 对象处理 ####
|
#### 对象处理 ####
|
||||||
|
|
||||||
- 通过交互式操作和调整数值来扭曲、移动、测量、旋转目标
|
- 通过交互式操作和调整参量来扭曲、移动、测量、旋转目标
|
||||||
- 执行力提升并减少了Z-order操作。
|
- 可以对 Z 轴进行提升或降低操作。
|
||||||
- 对象群组化或取消群组化可以去创建一个虚拟层阶用来编辑或处理
|
- 通过对象组合和取消组合可以创建一个虚拟层用来编辑或处理
|
||||||
- 图层采用层次结构树的结构并且能锁定或以各式各样的处理方式来重新布置
|
- 图层采用层次结构树的结构,并且能锁定或以各式各样的处理方式来重新布置
|
||||||
- 分布与对齐指令
|
- 分布与对齐指令
|
||||||
|
|
||||||
#### 填充与边框 ####
|
#### 填充与边框 ####
|
||||||
|
|
||||||
- 复制/粘贴风格
|
- 可以复制/粘贴不同风格
|
||||||
- 取色工具
|
- 取色工具
|
||||||
- 用RGB, HSL, CMS, CMYK和色盘这四种不同的方式选色
|
- 用RGB, HSL, CMS, CMYK和色盘这四种不同的方式选色
|
||||||
- 渐层编辑器能创建和管理多停点渐层
|
- 渐变层编辑器能创建和管理多停点渐变层
|
||||||
- 定义一个图像或其它选择用来进行花纹填充
|
- 使用图像或其它选择区作为花纹填充
|
||||||
- 用一些预定义泼洒花纹可对边框进行花纹泼洒
|
- 用一些预定义点状花纹进行笔触填充
|
||||||
- 通过路径标示器来开始、对折和结束标示
|
- 通过路径标示器标示开始、对折和结束点
|
||||||
|
|
||||||
#### 路径上的操作 ####
|
#### 路径上的操作 ####
|
||||||
|
|
||||||
- 节点编辑:移动节点和贝塞尔曲线掌控,节点的对齐和分布等等
|
- 节点编辑:移动节点和贝塞尔曲线控制点,节点的对齐和分布等等
|
||||||
- 布尔运算(是或否)
|
- 布尔运算(是或否)
|
||||||
- 运用可变的路径起迄点可简化路径
|
- 运用可变的路径起迄点可简化路径
|
||||||
- 路径插入和增设连同动态和链接偏移对象
|
- 路径插入和增设连同动态和链接偏移对象
|
||||||
@ -43,9 +43,9 @@ Inkscape始于2003年,起初它的bug跟踪系统托管于Sourceforge上但是
|
|||||||
|
|
||||||
#### 文本处理 ####
|
#### 文本处理 ####
|
||||||
|
|
||||||
- 所有安装好的外框字体都能用甚至可以从右至左对齐对象
|
- 所有安装好的框线字体都能用,甚至可以从右至左对齐对象
|
||||||
- 格式化文本、调整字母间距、行间距或列间距
|
- 格式化文本、调整字母间距、行间距或列间距
|
||||||
- 路径上的文本和形状上的文本和路径或形状都可以被编辑和修改
|
- 路径上和形状上的文本中的文本、路径或形状都可以被编辑和修改
|
||||||
|
|
||||||
#### 渲染 ####
|
#### 渲染 ####
|
||||||
|
|
||||||
@ -78,7 +78,7 @@ PPA添加到APT库中后,我们要用以下命令进行更新:
|
|||||||
|
|
||||||
### 结论 ###
|
### 结论 ###
|
||||||
|
|
||||||
Inkscape是一款特点鲜明的图形编辑工具,它给予用户充分发挥自己艺术力的权利。它还是一款自由安装和自定义开源应用并且支持大范围文件类型包括JPEG, PNG, GIF和PDF且不仅这些。访问它的 [官方网站][2] 来获取更多新闻和应用更新。
|
Inkscape是一款特点鲜明的图形编辑工具,它给予用户充分发挥自己艺术能力的权利。它还是一款自由安装和自定义的开源应用,并且支持各种文件类型,包括JPEG, PNG, GIF和PDF及更多。访问它的 [官方网站][2] 来获取更多新闻和应用更新。
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -86,7 +86,7 @@ via: http://linoxide.com/tools/install-inkscape-open-source-vector-graphic-edito
|
|||||||
|
|
||||||
作者:[Aun Raza][a]
|
作者:[Aun Raza][a]
|
||||||
译者:[ZTinoZ](https://github.com/ZTinoZ)
|
译者:[ZTinoZ](https://github.com/ZTinoZ)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,12 +1,13 @@
|
|||||||
Linux 上 wget 或 curl 的更佳替代品
|
用腻了 wget 或 curl,有什么更好的替代品吗?
|
||||||
================================================================================
|
================================================================================
|
||||||
如果你经常需要通过终端以非交互模式访问网络服务器(例如,从网络上下载文件,或者是测试 RESTful 网络服务接口),可能你会选择的工具是 wget 或 curl。通过大量的命令行选项,这两种工具都可以处理很多非交互网络访问的情况(比如[这里][1],[这里][2],还有[这里][3])。然而,即使像这些一样的强大的工具,也只是与你对如何使用它们的了解程度等同。除非你很精通那些又多又笨(原文是 nitty and gritty)的语法细节,这些工具对于你来说只不过是简单的网络下载器。
|
|
||||||
|
|
||||||
就像宣传的那样,“为人类着想的类 curl 工具”,[HTTPie][4] 设计用来增强 wget 和 curl 的可用性。它的主要目标是使通过命令行与网络服务器进行交互的过程变得尽可能的人性化。为此,HTTPie 支持具有表现力,但又很简单很直观的语法。它以彩色模式显示响应,并且还有一些不错的优点,比如对 JSON 的良好支持,和持久性会话用以作业流程化。
|
如果你经常需要通过终端以非交互模式访问网络服务器(例如,从网络上下载文件,或者是测试 RESTful 网络服务接口),可能你会选择的工具是 wget 或 curl。通过大量的命令行选项,这两种工具都可以处理很多非交互网络访问的情况(比如[这里][1]、[这里][2],还有[这里][3])。然而,即使像这些一样的强大的工具,你也只能发挥你所了解的那些选项的功能。除非你很精通那些繁冗的语法细节,这些工具对于你来说只不过是简单的网络下载器而已。
|
||||||
|
|
||||||
我知道很多人对把像 wget 和 curl 这样的无处不在的可用的完美工具换成完全没听说过的软件心存怀疑。这种观点是好的,特别是如果你是一个系统管理员、要处理很多不同的硬件的话。然而,对于开发者和终端用户来说,重要的是效率。如果我发现了一个工具的用户友好替代,我没有看到任何问题如果你采用易于使用的版本来节省你宝贵的时间。没有必要对替换掉的工具保持信仰忠诚。毕竟,对于 Linux 来说,最好的事情是可以选择。
|
就像其宣传的那样,“给人用 curl 类工具”,[HTTPie][4] 设计用来增强 wget 和 curl 的可用性。它的主要目标是使通过命令行与网络服务器进行交互的过程变得尽可能的人性化。为此,HTTPie 支持具有表现力、但又很简单很直观的语法。它以彩色模式显示响应,并且还有一些不错的优点,比如对 JSON 的良好支持,和持久性会话用以作业流程化。
|
||||||
|
|
||||||
在这篇文章中,让我们来回顾并展示一下我所说的 HTTPie,一个用户友好的 wget 和 curl 的替代。
|
我知道很多人对把像 wget 和 curl 这样的无处不在的、可用的、完美的工具换成完全没听说过的软件心存疑虑。这种观点是好的,特别是如果你是一个系统管理员、要处理很多不同的硬件的话。然而,对于开发者和终端用户来说,重要的是效率。如果我发现了一个工具的用户更佳替代品,那么我认为采用易于使用的版本来节省宝贵的时间是毫无疑问的。没有必要对替换掉的工具保持信仰忠诚。毕竟,对于 Linux 来说,最好的事情就是可以选择。
|
||||||
|
|
||||||
|
在这篇文章中,让我们来了解并展示一下我所说的 HTTPie,一个用户友好的 wget 和 curl 的替代。
|
||||||
|
|
||||||
![](https://farm8.staticflickr.com/7633/16849137018_bcc7a616fc_b.jpg)
|
![](https://farm8.staticflickr.com/7633/16849137018_bcc7a616fc_b.jpg)
|
||||||
|
|
||||||
@ -40,10 +41,9 @@ HTTPie 是用 Python 写的,所以你可以在几乎所有地方(Linux,Mac
|
|||||||
|
|
||||||
你可以使用 <header:value> 的格式来定制头部。例如,我们发送一个 HTTP GET 请求到 www.test.com ,使用定制用户代理(user-agent)和来源(referer),还有定制头部(比如 MyParam)。
|
你可以使用 <header:value> 的格式来定制头部。例如,我们发送一个 HTTP GET 请求到 www.test.com ,使用定制用户代理(user-agent)和来源(referer),还有定制头部(比如 MyParam)。
|
||||||
|
|
||||||
|
|
||||||
$ http www.test.com User-Agent:Xmodulo/1.0 Referer:http://xmodulo.com MyParam:Foo
|
$ http www.test.com User-Agent:Xmodulo/1.0 Referer:http://xmodulo.com MyParam:Foo
|
||||||
|
|
||||||
注意到当使用 HTTP GET 方法时,你无需指定任何 HTTP 方法。
|
注意到当使用 HTTP GET 方法时,就无需明确指定 HTTP 方法。
|
||||||
|
|
||||||
这个 HTTP 请求看起来如下:
|
这个 HTTP 请求看起来如下:
|
||||||
|
|
||||||
@ -121,7 +121,7 @@ HTTPie 的另外一个用户友好特性是输入重定向,你可以使用缓
|
|||||||
|
|
||||||
### 结束语 ###
|
### 结束语 ###
|
||||||
|
|
||||||
在这篇文章中,我介绍了 HTTPie,一个 wget 和 curl 的可能替代工具。除了这里展示的几个简单的例子,你可以在[官方网站][7]上找到 HTTPie 的很多有趣的应用。再次重复一遍,一款强大的工具也只相当于你对它的了解程度。从个人而言,我更热衷于 HTTPie,因为我在寻找一种更简洁的测试复杂网络接口的方法。
|
在这篇文章中,我介绍了 HTTPie,一个 wget 和 curl 的可能替代工具。除了这里展示的几个简单的例子,你可以在其[官方网站][7]上找到 HTTPie 的很多有趣的应用。再次重复一遍,一款再强大的工具也取决于你对它的了解程度。从个人而言,我更倾向于 HTTPie,因为我在寻找一种更简洁的测试复杂网络接口的方法。
|
||||||
|
|
||||||
你怎么看?
|
你怎么看?
|
||||||
|
|
||||||
@ -131,15 +131,15 @@ via: http://xmodulo.com/wget-curl-alternative-linux.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[wangjiezhe](https://github.com/wangjiezhe)
|
译者:[wangjiezhe](https://github.com/wangjiezhe)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
[a]:http://xmodulo.com/author/nanni
|
[a]:http://xmodulo.com/author/nanni
|
||||||
[1]:http://xmodulo.com/how-to-download-multiple-files-with-wget.html
|
[1]:http://xmodulo.com/how-to-download-multiple-files-with-wget.html
|
||||||
[2]:http://xmodulo.com/how-to-use-custom-http-headers-with-wget.html
|
[2]:http://xmodulo.com/how-to-use-custom-http-headers-with-wget.html
|
||||||
[3]:http://ask.xmodulo.com/custom-http-header-curl.html
|
[3]:https://linux.cn/article-4957-1.html
|
||||||
[4]:https://github.com/jakubroztocil/httpie
|
[4]:https://github.com/jakubroztocil/httpie
|
||||||
[5]:http://xmodulo.com/how-to-set-up-epel-repository-on-centos.html
|
[5]:https://linux.cn/article-2324-1.html
|
||||||
[6]:http://ask.xmodulo.com/install-pip-linux.html
|
[6]:http://ask.xmodulo.com/install-pip-linux.html
|
||||||
[7]:https://github.com/jakubroztocil/httpie
|
[7]:https://github.com/jakubroztocil/httpie
|
@ -1,12 +1,12 @@
|
|||||||
一些重要Docker命令的简单介绍
|
一些重要 Docker 命令的简单介绍
|
||||||
================================================================================
|
================================================================================
|
||||||
大家好,今天我们来学习一些在你使用Docker之前需要了解的重要的 Docker 命令。Docker 是一个提供开发平台去打包,装载和运行任何应用的轻量级容器开源项目。它没有语言支持,框架和打包系统的限制,能从一个小的家庭电脑到高端服务器,在任何地方任何时间运行。这使得它们成为不依赖于一个特定的栈或供应商,部署和扩展web应用,数据库和后端服务很好的构建块。
|
大家好,今天我们来学习一些在你使用 Docker 之前需要了解的重要的 Docker 命令。[Docker][1] 是一个开源项目,提供了一个可以打包、装载和运行任何应用的轻量级容器的开放平台。它没有语言支持、框架和打包系统的限制,从小型的家用电脑到高端服务器,在何时何地都可以运行。这使它们可以不依赖于特定软件栈和供应商,像一块块积木一样部署和扩展网络应用、数据库和后端服务。
|
||||||
|
|
||||||
Docker 命令简单易学,也很容易实现或实践。这是一些你运行 Docker 并充分利用它需要知道的简单 Docker 命令。
|
Docker 命令简单易学,也很容易实现或实践。这是一些你运行 Docker 并充分利用它需要知道的简单 Docker 命令。
|
||||||
|
|
||||||
### 1. 拉取一个 Docker 镜像 ###
|
### 1. 拉取 Docker 镜像 ###
|
||||||
|
|
||||||
由于容器是由 Docker 镜像构建的,首先我们需要拉取一个 docker 镜像来开始。我们可以从 Docker 注册 Hub 获取需要的 docker 镜像。在我们使用 pull 命令拉取任何镜像之前,由于pull命令被标识为恶意命令,我们需要保护我们的系统。为了保护我们的系统不受这个问题影响,我们需要添加 **127.0.0.1 index.docker.io** 到 /etc/hosts 条目。我们可以通过使用喜欢的文本编辑器完成。
|
由于容器是由 Docker 镜像构建的,首先我们需要拉取一个 docker 镜像来开始。我们可以从 Docker Registry Hub 获取所需的 docker 镜像。在我们使用 pull 命令拉取任何镜像之前,为了避免 pull 命令的一些恶意风险,我们需要保护我们的系统。为了保护我们的系统不受这个风险影响,我们需要添加 **127.0.0.1 index.docker.io** 到 /etc/hosts 条目。我们可以通过使用喜欢的文本编辑器完成。
|
||||||
|
|
||||||
# nano /etc/hosts
|
# nano /etc/hosts
|
||||||
|
|
||||||
@ -16,7 +16,7 @@ Docker 命令简单易学,也很容易实现或实践。这是一些你运行
|
|||||||
|
|
||||||
![Docker 宿主机](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-hosts.png)
|
![Docker 宿主机](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-hosts.png)
|
||||||
|
|
||||||
要拉取一个 docker 进行,我们需要运行下面的命令。
|
要拉取一个 docker 镜像,我们需要运行下面的命令。
|
||||||
|
|
||||||
# docker pull registry.hub.docker.com/busybox
|
# docker pull registry.hub.docker.com/busybox
|
||||||
|
|
||||||
@ -28,9 +28,9 @@ Docker 命令简单易学,也很容易实现或实践。这是一些你运行
|
|||||||
|
|
||||||
![Docker 镜像](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-images.png)
|
![Docker 镜像](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-images.png)
|
||||||
|
|
||||||
### 2. 运行一个 Docker 容器 ###
|
### 2. 运行 Docker 容器 ###
|
||||||
|
|
||||||
现在,成功地拉取要求或需要的 Docker 镜像之后,我们当然想运行这个 Docker 镜像。我们可以用 docker run 命令在镜像上运行一个 docker 容器。在 Docker 镜像之上运行一个 docker 容易时我们有很多选项和标记。我们使用 -t 和 -i 标记运行一个 docker 镜像并进入容器,如下面所示。
|
现在,成功地拉取要求的或所需的 Docker 镜像之后,我们当然想运行这个 Docker 镜像。我们可以用 docker run 命令在镜像上运行一个 docker 容器。在 Docker 镜像上运行一个 docker 容器时我们有很多选项和标记。我们使用 -t 和 -i 选项来运行一个 docker 镜像并进入容器,如下面所示。
|
||||||
|
|
||||||
# docker run -it busybox
|
# docker run -it busybox
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ Docker 命令简单易学,也很容易实现或实践。这是一些你运行
|
|||||||
|
|
||||||
![进入Docker](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-attach.png)
|
![进入Docker](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-attach.png)
|
||||||
|
|
||||||
### 3. 查看容器 ###
|
### 3. 检查容器运行 ###
|
||||||
|
|
||||||
不论容器是否运行,查看日志文件都很简单。我们可以使用下面的命令去检查是否有 docker 容器在实时运行。
|
不论容器是否运行,查看日志文件都很简单。我们可以使用下面的命令去检查是否有 docker 容器在实时运行。
|
||||||
|
|
||||||
@ -62,17 +62,17 @@ Docker 命令简单易学,也很容易实现或实践。这是一些你运行
|
|||||||
|
|
||||||
![查看 Docker 容器](http://blog.linoxide.com/wp-content/uploads/2015/04/view-docker-containers1.png)
|
![查看 Docker 容器](http://blog.linoxide.com/wp-content/uploads/2015/04/view-docker-containers1.png)
|
||||||
|
|
||||||
### 4. 检查 Docker 容器 ###
|
### 4. 查看容器信息 ###
|
||||||
|
|
||||||
我们可以使用 inspect 命令检查一个 Docker 容器的每条信息。
|
我们可以使用 inspect 命令查看一个 Docker 容器的各种信息。
|
||||||
|
|
||||||
# docker inspect <container id>
|
# docker inspect <container id>
|
||||||
|
|
||||||
![检查Docker](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-inspect.png)
|
![检查Docker](http://blog.linoxide.com/wp-content/uploads/2015/04/docker-inspect.png)
|
||||||
|
|
||||||
### 5. 杀死或删除命令 ###
|
### 5. 杀死或删除 ###
|
||||||
|
|
||||||
我们可以使用 docker id 杀死或者停止进程或 docker 容器,如下所示。
|
我们可以使用容器 id 杀死或者停止 docker 容器(进程),如下所示。
|
||||||
|
|
||||||
# docker stop <container id>
|
# docker stop <container id>
|
||||||
|
|
||||||
@ -90,7 +90,7 @@ Docker 命令简单易学,也很容易实现或实践。这是一些你运行
|
|||||||
|
|
||||||
### 结论 ###
|
### 结论 ###
|
||||||
|
|
||||||
这些都是学习充分实现和利用 Docker 很基本的 docker 命令。有了这些命令,Docker 变得很简单,提供给端用户一个简单的计算平台。根据上面的教程,任何人学习 Docker 命令都非常简单。如果你有任何问题,建议,反馈,请写到下面的评论框中以便我们改进和更新内容。多谢!享受吧 :-)
|
这些都是充分学习和使用 Docker 很基本的 docker 命令。有了这些命令,Docker 变得很简单,可以提供给最终用户一个易用的计算平台。根据上面的教程,任何人学习 Docker 命令都非常简单。如果你有任何问题,建议,反馈,请写到下面的评论框中以便我们改进和更新内容。多谢! 希望你喜欢 :-)
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -98,8 +98,9 @@ via: http://linoxide.com/linux-how-to/important-docker-commands/
|
|||||||
|
|
||||||
作者:[Arun Pyasi][a]
|
作者:[Arun Pyasi][a]
|
||||||
译者:[ictlyh](https://github.com/ictlyh)
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
[a]:http://linoxide.com/author/arunp/
|
[a]:http://linoxide.com/author/arunp/
|
||||||
|
[1]:https://www.docker.com/
|
@ -1,4 +1,4 @@
|
|||||||
Linux有问必答--如何在Linux中修改环境变量PATH
|
Linux有问必答:如何在Linux中修改环境变量PATH
|
||||||
================================================================================
|
================================================================================
|
||||||
> **提问**: 当我试着运行一个程序时,它提示“command not found”。 但这个程序就在/usr/local/bin下。我该如何添加/usr/local/bin到我的PATH变量下,这样我就可以不用指定路径来运行这个命令了。
|
> **提问**: 当我试着运行一个程序时,它提示“command not found”。 但这个程序就在/usr/local/bin下。我该如何添加/usr/local/bin到我的PATH变量下,这样我就可以不用指定路径来运行这个命令了。
|
||||||
|
|
||||||
@ -38,7 +38,7 @@ Linux有问必答--如何在Linux中修改环境变量PATH
|
|||||||
|
|
||||||
/usr/lib64/qt-3.3/bin:/bin:/usr/bin:/usr/sbin:/sbin:/home/xmodulo/bin:/usr/local/bin
|
/usr/lib64/qt-3.3/bin:/bin:/usr/bin:/usr/sbin:/sbin:/home/xmodulo/bin:/usr/local/bin
|
||||||
|
|
||||||
更新的PATH会在当前的PATH一直有效。然而,更改将在新的会话中失效。
|
更新后的PATH会在当前的会话一直有效。然而,更改将在新的会话中失效。
|
||||||
|
|
||||||
如果你想要永久更改PATH变量,用编辑器打开~/.bashrc (或者 ~/.bash_profile),接着在最后添加下面这行。
|
如果你想要永久更改PATH变量,用编辑器打开~/.bashrc (或者 ~/.bash_profile),接着在最后添加下面这行。
|
||||||
|
|
||||||
@ -46,7 +46,7 @@ Linux有问必答--如何在Linux中修改环境变量PATH
|
|||||||
|
|
||||||
接着运行下面这行永久激活更改:
|
接着运行下面这行永久激活更改:
|
||||||
|
|
||||||
$ source ~/.bashrc (or source ~/.bash_profile)
|
$ source ~/.bashrc (或者 source ~/.bash_profile)
|
||||||
|
|
||||||
### 改变系统级的环境变量 ###
|
### 改变系统级的环境变量 ###
|
||||||
|
|
||||||
@ -66,7 +66,7 @@ via: http://ask.xmodulo.com/change-path-environment-variable-linux.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[geekpi](https://github.com/geekpi)
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
[已解决] Ubuntu下不能记住亮度设置问题
|
如何解决 Ubuntu 下不能记住亮度设置的问题
|
||||||
================================================================================
|
================================================================================
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/04/Fix_Ubuntu_Brightness_Issue.jpg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/04/Fix_Ubuntu_Brightness_Issue.jpg)
|
||||||
|
|
||||||
@ -22,7 +22,7 @@ via: http://itsfoss.com/ubuntu-mint-brightness-settings/
|
|||||||
|
|
||||||
作者:[Abhishek][a]
|
作者:[Abhishek][a]
|
||||||
译者:[ZTinoZ](https://github.com/ZTinoZ)
|
译者:[ZTinoZ](https://github.com/ZTinoZ)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,22 +1,26 @@
|
|||||||
如何在 CentOS Linux 中配置 MariADB 复制
|
如何在 CentOS Linux 中配置 MariaDB 复制
|
||||||
================================================================================
|
================================================================================
|
||||||
这是一个创建数据库重复版本的过程。复制过程不仅仅是复制一个数据库,同时也包括从主节点到一个从节点的更改同步。但这并不意味着从数据库就是和主数据库完全相同的副本,因为复制可以配置为只有表或者行或者列的一个模式将被复制,例如,局部复制。复制保证了特定的配置对象在不同的数据库之间保持同步。
|
这是一个创建数据库重复版本的过程。复制过程不仅仅是复制一个数据库,同时也包括从主节点到一个从节点的更改同步。但这并不意味着从数据库就是和主数据库完全相同的副本,因为复制可以配置为只复制表结构、行或者列,这叫做局部复制。复制保证了特定的配置对象在不同的数据库之间保持一致。
|
||||||
|
|
||||||
### Mariadb 复制概念 ###
|
### Mariadb 复制概念 ###
|
||||||
|
|
||||||
**备份** :复制可以用来进行数据库备份。例如,你有主->从复制。如果主节点丢失(比如hdd损坏),你可以从从节点中恢复你的数据库。
|
**备份** :复制可以用来进行数据库备份。例如,当你做了主->从复制。如果主节点数据丢失(比如硬盘损坏),你可以从从节点中恢复你的数据库。
|
||||||
|
|
||||||
**扩展** :你可以使用主->从复制作为扩展的解决方案。例如,如果你有一些大的数据库以及SQL查询,使用复制你可以将这些查询单独分到每个复制节点。写SQL应该只在主节点进行,而只读查询可以在从节点上进行。
|
**扩展** :你可以使用主->从复制作为扩展解决方案。例如,如果你有一些大的数据库以及SQL查询,使用复制你可以将这些查询分离到每个复制节点。写入操作的SQL应该只在主节点进行,而只读查询可以在从节点上进行。
|
||||||
|
|
||||||
**传播解决方案** :你可以用复制来进行分发。例如,你可以将不同的销售数据分发到不同的数据库。
|
**分发解决方案** :你可以用复制来进行分发。例如,你可以将不同的销售数据分发到不同的数据库。
|
||||||
|
|
||||||
**故障解决方案** : 假如你有主节点->从节点1->从节点2->从节点3的复制。你可以为主节点写脚本监控,如果主节点出故障了,脚本可以快速的将从节点1作为新的主节点,有主节点->从节点1->从节点2,你的应用可以继续工作而不会停机。
|
**故障解决方案** : 假如你建立有主节点->从节点1->从节点2->从节点3的复制结构。你可以为主节点写脚本监控,如果主节点出故障了,脚本可以快速的将从节点1切换为新的主节点,这样复制结构变成了主节点->从节点1->从节点2,你的应用可以继续工作而不会停机。
|
||||||
|
|
||||||
### 复制的简单图解示范 ###
|
### 复制的简单图解示范 ###
|
||||||
|
|
||||||
![mysql 复制原理](http://blog.linoxide.com/wp-content/uploads/2015/04/mysql-replication-principle.png)
|
![mysql 复制原理](http://blog.linoxide.com/wp-content/uploads/2015/04/mysql-replication-principle.png)
|
||||||
|
|
||||||
开始之前,你应该知道什么是**二进制日志文件**以及 Ibdata1。二进制日志文件中包括关于数据库,数据和结构的所有更改的记录,以及每条语句的执行时间。二进制日志文件包括设置日志文件和一个索引。这意味着主要的SQL语句,例如CREATE, ALTER, INSERT, UPDATE 和 DELETE 会放到这个日志文件中,而例如SELECT语句就不会被记录。这些信息可以被记录到普通的query.log文件。简单的说 **Ibdata1** 是一个包括所有表和所有数据库信息的文件。
|
开始之前,你应该知道什么是**二进制日志文件**以及 Ibdata1。
|
||||||
|
|
||||||
|
二进制日志文件中包括关于数据库,数据和结构的所有更改的记录,以及每条语句的执行了多长时间。二进制日志文件包括一系列日志文件和一个索引文件。这意味着主要的SQL语句,例如CREATE, ALTER, INSERT, UPDATE 和 DELETE 会放到这个日志文件中;而例如SELECT这样的语句就不会被记录,它们可以被记录到普通的query.log文件中。
|
||||||
|
|
||||||
|
而 **Ibdata1** 简单的说据是一个包括所有表和所有数据库信息的文件。
|
||||||
|
|
||||||
### 主服务器配置 ###
|
### 主服务器配置 ###
|
||||||
|
|
||||||
@ -39,7 +43,7 @@
|
|||||||
sudo systemctl start mariadb.service
|
sudo systemctl start mariadb.service
|
||||||
sudo systemctl enable mariadb.service
|
sudo systemctl enable mariadb.service
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
ln -s '/usr/lib/systemd/system/mariadb.service' '/etc/systemd/system/multi-user.target.wants/mariadb.service'
|
ln -s '/usr/lib/systemd/system/mariadb.service' '/etc/systemd/system/multi-user.target.wants/mariadb.service'
|
||||||
|
|
||||||
@ -51,7 +55,7 @@
|
|||||||
|
|
||||||
sudo systemctl is-active mariadb.service
|
sudo systemctl is-active mariadb.service
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
Redirecting to /bin/systemctl status mariadb.service
|
Redirecting to /bin/systemctl status mariadb.service
|
||||||
mariadb.service - MariaDB database server
|
mariadb.service - MariaDB database server
|
||||||
@ -65,11 +69,11 @@
|
|||||||
mysql> flush privileges;
|
mysql> flush privileges;
|
||||||
mysql> exit
|
mysql> exit
|
||||||
|
|
||||||
SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后尝试登陆:
|
这里 SOME_ROOT_PASSWORD 是你的 root 密码。 例如我用"q"作为密码,然后尝试登录:
|
||||||
|
|
||||||
sudo mysql -u root -pSOME_ROOT_PASSWORD
|
sudo mysql -u root -pSOME_ROOT_PASSWORD
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
Welcome to the MariaDB monitor. Commands end with ; or \g.
|
Welcome to the MariaDB monitor. Commands end with ; or \g.
|
||||||
Your MariaDB connection id is 5
|
Your MariaDB connection id is 5
|
||||||
@ -89,7 +93,7 @@ SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后
|
|||||||
|
|
||||||
test_repl - 将要被复制的模式的名字
|
test_repl - 将要被复制的模式的名字
|
||||||
|
|
||||||
输出:
|
输出:如下
|
||||||
|
|
||||||
Query OK, 1 row affected (0.00 sec)
|
Query OK, 1 row affected (0.00 sec)
|
||||||
|
|
||||||
@ -105,7 +109,7 @@ SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后
|
|||||||
City varchar(255)
|
City varchar(255)
|
||||||
);
|
);
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
mysql> MariaDB [test_repl]> CREATE TABLE Persons (
|
mysql> MariaDB [test_repl]> CREATE TABLE Persons (
|
||||||
-> PersonID int,
|
-> PersonID int,
|
||||||
@ -124,7 +128,7 @@ SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后
|
|||||||
mysql> INSERT INTO Persons VALUES (4, "LastName4", "FirstName4", "Address4", "City4");
|
mysql> INSERT INTO Persons VALUES (4, "LastName4", "FirstName4", "Address4", "City4");
|
||||||
mysql> INSERT INTO Persons VALUES (5, "LastName5", "FirstName5", "Address5", "City5");
|
mysql> INSERT INTO Persons VALUES (5, "LastName5", "FirstName5", "Address5", "City5");
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
Query OK, 5 row affected (0.00 sec)
|
Query OK, 5 row affected (0.00 sec)
|
||||||
|
|
||||||
@ -132,7 +136,7 @@ SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后
|
|||||||
|
|
||||||
mysql> select * from Persons;
|
mysql> select * from Persons;
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
+----------+-----------+------------+----------+-------+
|
+----------+-----------+------------+----------+-------+
|
||||||
| PersonID | LastName | FirstName | Address | City |
|
| PersonID | LastName | FirstName | Address | City |
|
||||||
@ -145,9 +149,9 @@ SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后
|
|||||||
| 5 | LastName5 | FirstName5 | Address5 | City5 |
|
| 5 | LastName5 | FirstName5 | Address5 | City5 |
|
||||||
+----------+-----------+------------+----------+-------+
|
+----------+-----------+------------+----------+-------+
|
||||||
|
|
||||||
### 配置 MariaDB 重复 ###
|
### 配置 MariaDB 复制 ###
|
||||||
|
|
||||||
你需要在主结点服务器上编辑 my.cnf文件来启用二进制日志以及设置服务器id。我会使用vi文本编辑器,但你可以使用任何你喜欢的,例如nano,joe。
|
你需要在主节点服务器上编辑 my.cnf文件来启用二进制日志以及设置服务器id。我会使用vi文本编辑器,但你可以使用任何你喜欢的,例如nano,joe。
|
||||||
|
|
||||||
sudo vi /etc/my.cnf
|
sudo vi /etc/my.cnf
|
||||||
|
|
||||||
@ -159,7 +163,7 @@ SOME_ROOT_PASSWORD - 你的 root 密码。 例如我用"q"作为密码,然后
|
|||||||
binlog-format=row
|
binlog-format=row
|
||||||
server_id=1
|
server_id=1
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
![mariadb 配置主节点](http://blog.linoxide.com/wp-content/uploads/2015/04/mariadb-config.png)
|
![mariadb 配置主节点](http://blog.linoxide.com/wp-content/uploads/2015/04/mariadb-config.png)
|
||||||
|
|
||||||
@ -173,7 +177,7 @@ sudo mysql -u root -pq test_repl
|
|||||||
|
|
||||||
mysql> SHOW MASTER STATUS;
|
mysql> SHOW MASTER STATUS;
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
+--------------------+----------+--------------+------------------+
|
+--------------------+----------+--------------+------------------+
|
||||||
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
|
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
|
||||||
@ -183,12 +187,12 @@ mysql> SHOW MASTER STATUS;
|
|||||||
|
|
||||||
**记住** : "File" 和 "Position" 的值。在从节点中你需要使用这些值
|
**记住** : "File" 和 "Position" 的值。在从节点中你需要使用这些值
|
||||||
|
|
||||||
创建用来重复的用户
|
创建用来复制的用户
|
||||||
|
|
||||||
mysql> GRANT REPLICATION SLAVE ON *.* TO replication_user IDENTIFIED BY 'bigs3cret' WITH GRANT OPTION;
|
mysql> GRANT REPLICATION SLAVE ON *.* TO replication_user IDENTIFIED BY 'bigs3cret' WITH GRANT OPTION;
|
||||||
mysql> flush privileges;
|
mysql> flush privileges;
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
Query OK, 0 rows affected (0.00 sec)
|
Query OK, 0 rows affected (0.00 sec)
|
||||||
Query OK, 0 rows affected (0.00 sec)
|
Query OK, 0 rows affected (0.00 sec)
|
||||||
@ -197,7 +201,7 @@ mysql> SHOW MASTER STATUS;
|
|||||||
|
|
||||||
mysql> select * from mysql.user WHERE user="replication_user"\G;
|
mysql> select * from mysql.user WHERE user="replication_user"\G;
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
mysql> select * from mysql.user WHERE user="replication_user"\G;
|
mysql> select * from mysql.user WHERE user="replication_user"\G;
|
||||||
*************************** 1. row ***************************
|
*************************** 1. row ***************************
|
||||||
@ -220,11 +224,11 @@ mysql> SHOW MASTER STATUS;
|
|||||||
|
|
||||||
### 从节点配置 ###
|
### 从节点配置 ###
|
||||||
|
|
||||||
所有这些命令需要在从节点中进行
|
所有这些命令需要在从节点中进行。
|
||||||
|
|
||||||
假设我们已经更新/升级了包括有最新的MariaDB服务器的 CentOS 7.x,而且你可以用root账号登陆到MariaDBs服务器(这在这篇文章的第一部分已经介绍过)
|
假设我们已经更新/升级了包括有最新的MariaDB服务器的 CentOS 7.x,而且你可以用root账号登陆到MariaDB服务器(这在这篇文章的第一部分已经介绍过)
|
||||||
|
|
||||||
登陆到Maria 数据库控制台并创建数据库
|
登录到Maria 数据库控制台并创建数据库
|
||||||
|
|
||||||
mysql -u root -pSOME_ROOT_PASSWORD;
|
mysql -u root -pSOME_ROOT_PASSWORD;
|
||||||
mysql> create database test_repl;
|
mysql> create database test_repl;
|
||||||
@ -264,7 +268,7 @@ full-dump.sql - 你在测试服务器中创建的DB Dump。
|
|||||||
|
|
||||||
mysql> slave start;
|
mysql> slave start;
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
Query OK, 0 rows affected (0.00 sec)
|
Query OK, 0 rows affected (0.00 sec)
|
||||||
|
|
||||||
@ -272,7 +276,7 @@ full-dump.sql - 你在测试服务器中创建的DB Dump。
|
|||||||
|
|
||||||
mysql> show slave status\G;
|
mysql> show slave status\G;
|
||||||
|
|
||||||
输出:
|
输出如下:
|
||||||
|
|
||||||
*************************** 1. row ***************************
|
*************************** 1. row ***************************
|
||||||
Slave_IO_State: Waiting for master to send event
|
Slave_IO_State: Waiting for master to send event
|
||||||
@ -352,7 +356,7 @@ via: http://linoxide.com/how-tos/configure-mariadb-replication-centos-linux/
|
|||||||
|
|
||||||
作者:[Bobbin Zachariah][a]
|
作者:[Bobbin Zachariah][a]
|
||||||
译者:[ictlyh](https://github.com/ictlyh)
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,9 +1,8 @@
|
|||||||
sshuttle - 一个使用ssh的基于VPN的透明代理
|
sshuttle:一个使用ssh的基于VPN的透明代理
|
||||||
================================================================================
|
================================================================================
|
||||||
sshuttle允许你通过ssh创建一条从你电脑连接到任何远程服务器的VPN连接,只要你的服务器支持python2.3 或则更高的版本, 你必须有本机的root权限,但是你可以在服务端有普通账户即可。
|
sshuttle 允许你通过 ssh 创建一条从你电脑连接到任何远程服务器的 VPN 连接,只要你的服务器支持 python2.3 或则更高的版本。你必须有本机的 root 权限,但是你可以在服务端有普通账户即可。
|
||||||
|
|
||||||
你可以在一台机器上同时运行多次sshuttle来连接到不同的服务器上,这样你就可以一次使用多个VPN, sshuttle可以转发你子网所有流量到VPN中。
|
|
||||||
|
|
||||||
|
你可以在一台机器上同时运行多次 sshuttle 来连接到不同的服务器上,这样你就可以同时使用多个 VPN, sshuttle可以转发你子网中所有流量到VPN中。
|
||||||
|
|
||||||
### 在Ubuntu中安装sshuttle ###
|
### 在Ubuntu中安装sshuttle ###
|
||||||
|
|
||||||
@ -17,7 +16,7 @@ sshuttle允许你通过ssh创建一条从你电脑连接到任何远程服务器
|
|||||||
|
|
||||||
sshuttle [options...] [-r [username@]sshserver[:port]] [subnets]
|
sshuttle [options...] [-r [username@]sshserver[:port]] [subnets]
|
||||||
|
|
||||||
#### Option 细节 ####
|
#### 选项细节 ####
|
||||||
|
|
||||||
-r, —remote=[username@]sshserver[:port]
|
-r, —remote=[username@]sshserver[:port]
|
||||||
|
|
||||||
@ -29,9 +28,9 @@ sshuttle允许你通过ssh创建一条从你电脑连接到任何远程服务器
|
|||||||
|
|
||||||
sudo sshuttle -r username@sshserver 0.0.0.0/0 -vv
|
sudo sshuttle -r username@sshserver 0.0.0.0/0 -vv
|
||||||
|
|
||||||
当开始后,sshuttle会创建一个ssh会话到通过-r指定的服务器。如果-r被忽略了,它会在本地运行客户端和服务端,这个有时会在测试时有用。
|
当开始后,sshuttle会创建一个ssh会话到由-r指定的服务器。如果-r被丢了,它会在本地运行客户端和服务端,这个有时会在测试时有用。
|
||||||
|
|
||||||
连接到远程服务器后,sshuttle会上传它的(python)源码到远程服务器并执行。那么,你就不需要在远程服务器上安装sshuttle,并且客户端和服务器端间不会存在sshuttle版本冲突。
|
连接到远程服务器后,sshuttle会上传它的(python)源码到远程服务器并执行。所以,你就不需要在远程服务器上安装sshuttle,并且客户端和服务器端间不会存在sshuttle版本冲突。
|
||||||
|
|
||||||
#### 手册中的更多例子 ####
|
#### 手册中的更多例子 ####
|
||||||
|
|
||||||
@ -86,7 +85,7 @@ via: http://www.ubuntugeek.com/sshuttle-a-transparent-proxy-based-vpn-using-ssh.
|
|||||||
|
|
||||||
作者:[ruchi][a]
|
作者:[ruchi][a]
|
||||||
译者:[geekpi](https://github.com/geekpi)
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -1,22 +1,22 @@
|
|||||||
Docker 1.6 发布 - 如何在Fedora / CentOS上面升级
|
如何在Fedora / CentOS上面升级Docker 1.6
|
||||||
=============================================================================
|
=============================================================================
|
||||||
Docker,一个为软件打包的流行开源容器平台,有了新的发行版1.6,增加了许多新的特性。该版本在Docker注册,引擎,云集,组合和机器方面都有更新。这次发行旨在提升体验,开发者和系统管理员的经验(这里不太确定)。让我们来快速看看有哪些新特性吧。
|
Docker,一个流行的将软件打包的开源容器平台,已经有了新的1.6版,增加了许多新的特性。该版本主要更新了Docker Registry、Engine、 Swarm、 Compose 和 Machine等方面。这次发布旨在提升性能、改善开发者和系统管理员的体验。让我们来快速看看有哪些新特性吧。
|
||||||
|
|
||||||
**Docker Registry (2.0)**是一项推送Docker镜像用于存储和分享的服务,经历过架构的改变,因为面临加载下的体验问题。它仍然向下兼容。Docker Registry的编写语言现在从Python改为Google的Go语言了,为了提升表现力。与Docker引擎1.6结合后,拉取镜像的能力更快了。早先的镜像被队列式地输送,而现在是并行的啦。
|
**Docker Registry (2.0)**是一项推送Docker镜像用于存储和分享的服务,因为面临加载下的体验问题而经历了架构的改变。它仍然向后兼容。Docker Registry的编写语言现在从Python改为Google的Go语言了,以提升性能。与Docker Engine 1.6结合后,拉取镜像的能力更快了。早先的镜像是队列式输送的,而现在是并行的啦。
|
||||||
|
|
||||||
**Docker Engine (1.6)**相比之前的版本有很大的提高。目前支持容器与镜像标签。通过标签,你可以附加用户自定义的元数据到镜像和容器上,而镜像和容器反过来可以被其他工具使用。标签对正在运行的应用是不可见的,可以用来加速搜索容器和镜像。
|
**Docker Engine (1.6)**相比之前的版本有很大的提高。目前支持容器与镜像的标签。通过标签,你可以附加用户自定义的元数据到镜像和容器上,而镜像和容器反过来可以被其他工具使用。标签对正在运行的应用是不可见的,可以用来加速搜索容器和镜像。
|
||||||
|
|
||||||
Windows版本的Docker客户端可以连接一个远程的运行linux的Docker引擎。
|
Windows版本的Docker客户端可以连接到远程的运行在linux上的Docker Engine。
|
||||||
|
|
||||||
Docker目前支持日志驱动API,这允许我们发送容器日志给系统如Syslog,或者第三方。这将会使得系统管理员受益。
|
Docker目前支持日志驱动API,这允许我们发送容器日志给系统如Syslog,或者第三方。这将会使得系统管理员受益。
|
||||||
|
|
||||||
**Swarm (0.2)**是一个Docker集群工具,将一个Docker主机池转换为一个虚拟主机。在新特性里,容器甚至被放在了可用的节点上。通过添加更多的Docker命令,所有的努力都朝着支持完整的Docker API。将来,使用第三方驱动来集群会成为可能。
|
**Swarm (0.2)**是一个Docker集群工具,可以将一个Docker主机池转换为一个虚拟主机。在新特性里,容器甚至被放在了可用的节点上。通过添加更多的Docker命令,努力支持完整的Docker API。将来,使用第三方驱动来集群会成为可能。
|
||||||
|
|
||||||
**Compose (1.2)** 是一个Docker里定义和运行复杂应用的工具, 也得到了升级。在新版本里,一个可以创建多个子文件,而不是一个没有结构的文件描述一个多容器应用。
|
**Compose (1.2)** 是一个Docker里定义和运行复杂应用的工具, 也得到了升级。在新版本里,可以创建多个子文件,而不是用一个没有结构的文件描述一个多容器应用。
|
||||||
|
|
||||||
通过**Machine (0.2)**,我们可以很容易地在本地计算机,云和数据中心上搭建Docker主机。新的发行版为开发者提供了一个相对干净地驱动界面来写驱动。供应被Machine牢牢地掌握,而不是每个独立的驱动。新的命令被添加,可以用来生成主机的TLS证书,以提高安全性。
|
通过**Machine (0.2)**,我们可以很容易地在本地计算机、云和数据中心上搭建Docker主机。新的发布版本为开发者提供了一个相对干净地驱动界面来编写驱动。Machine集中控制供给,而不是每个独立的驱动。增加了新的命令,可以用来生成主机的TLS证书,以提高安全性。
|
||||||
|
|
||||||
### 在Fedora / CentOS 上升级架构 ###
|
### 在Fedora / CentOS 上的升级指导 ###
|
||||||
|
|
||||||
在这一部分里,我们将会学习如何在Fedora和CentOS上升级已有的docker到最新版本。请注意,目前的Docker仅运行在64位的架构上,Fedora和CentOS都源于RedHat,命令的使用是差不多相同的,除了在Fedora20和CentOS6.5里Docker包被叫做“docker-io”。
|
在这一部分里,我们将会学习如何在Fedora和CentOS上升级已有的docker到最新版本。请注意,目前的Docker仅运行在64位的架构上,Fedora和CentOS都源于RedHat,命令的使用是差不多相同的,除了在Fedora20和CentOS6.5里Docker包被叫做“docker-io”。
|
||||||
|
|
||||||
@ -28,7 +28,7 @@ Docker目前支持日志驱动API,这允许我们发送容器日志给系统
|
|||||||
|
|
||||||
在升级之前,备份一下docker镜像和容器卷是个不错的主意。
|
在升级之前,备份一下docker镜像和容器卷是个不错的主意。
|
||||||
|
|
||||||
参考[filesystem to a tar archive][1]与[volumes backups, restores or migrations options][2],获取更多信息。
|
参考[“将文件系统打成 tar 包”][1]与[“卷备份、恢复或迁移”][2],获取更多信息。
|
||||||
|
|
||||||
目前,测试系统安装了Docker1.5。样例输出显示是来自一个Fedora20的系统。
|
目前,测试系统安装了Docker1.5。样例输出显示是来自一个Fedora20的系统。
|
||||||
|
|
||||||
@ -42,7 +42,7 @@ Docker目前支持日志驱动API,这允许我们发送容器日志给系统
|
|||||||
|
|
||||||
[root@TestNode1 ~]# sudo systemctl stop docker
|
[root@TestNode1 ~]# sudo systemctl stop docker
|
||||||
|
|
||||||
升级到最新版使用yum update。但是写这篇文章的时候,仓库并不是最新版本(1.6)。因此你需要使用二进制的升级方法。
|
使用yum update升级到最新版,但是写这篇文章的时候,仓库并不是最新版本(1.6),因此你需要使用二进制的升级方法。
|
||||||
|
|
||||||
[root@TestNode1 ~]#sudo yum -y update docker-io
|
[root@TestNode1 ~]#sudo yum -y update docker-io
|
||||||
|
|
||||||
@ -66,7 +66,7 @@ Docker目前支持日志驱动API,这允许我们发送容器日志给系统
|
|||||||
|
|
||||||
2015-04-19 13:40:50 (8.72 MB/s) - /usr/bin/docker saved
|
2015-04-19 13:40:50 (8.72 MB/s) - /usr/bin/docker saved
|
||||||
|
|
||||||
检查更新版本
|
检查更新后的版本
|
||||||
|
|
||||||
[root@TestNode1 ~]#sudo docker -v
|
[root@TestNode1 ~]#sudo docker -v
|
||||||
|
|
||||||
@ -88,7 +88,7 @@ Docker目前支持日志驱动API,这允许我们发送容器日志给系统
|
|||||||
|
|
||||||
Hello World
|
Hello World
|
||||||
|
|
||||||
CentOS安装时需要**注意**,在CentOS上安装完Docker后,当你试图启动Docker服务的时候,你可能会得到错误的信息,如下所示
|
CentOS安装时需要**注意**,在CentOS上安装完Docker后,当你试图启动Docker服务的时候,你可能会得到错误的信息,如下所示:
|
||||||
|
|
||||||
docker.service - Docker Application Container Engine
|
docker.service - Docker Application Container Engine
|
||||||
|
|
||||||
@ -116,7 +116,7 @@ CentOS安装时需要**注意**,在CentOS上安装完Docker后,当你试图
|
|||||||
|
|
||||||
Apr 20 03:24:24 centos7 systemd[1]: Unit docker.service entered failed state.
|
Apr 20 03:24:24 centos7 systemd[1]: Unit docker.service entered failed state.
|
||||||
|
|
||||||
这是一个熟知的bug([https://bugzilla.redhat.com/show_bug.cgi?id=1207839][3]),需要一个设备映射的升级,到最新的水平。
|
这是一个已知的bug([https://bugzilla.redhat.com/show_bug.cgi?id=1207839][3]),需要将设备映射升级到最新。
|
||||||
|
|
||||||
[root@centos7 ~]# rpm -qa device-mapper
|
[root@centos7 ~]# rpm -qa device-mapper
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ CentOS安装时需要**注意**,在CentOS上安装完Docker后,当你试图
|
|||||||
|
|
||||||
### 总结 ###
|
### 总结 ###
|
||||||
|
|
||||||
尽管docker技术出现时间不长,当很快获得了流行。它使得开发者的生活变得容易,运维团队可以快速独立地创建和部署应用。通过公司发布快速的Docker更新,来提升产品质量,满足用户需求,未来对于Docker来说一片光明。
|
尽管docker技术出现时间不长,但很快就变得非常流行了。它使得开发者的生活变得轻松,运维团队可以快速独立地创建和部署应用。通过该公司的发布,Docker的快速更新,产品质量的提升,满足用户需求,未来对于Docker来说一片光明。
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ via: http://linoxide.com/linux-how-to/docker-1-6-features-upgrade-fedora-centos/
|
|||||||
|
|
||||||
作者:[B N Poornima][a]
|
作者:[B N Poornima][a]
|
||||||
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,38 @@
|
|||||||
|
Synfig Studio 1.0:开源动画动真格的了
|
||||||
|
================================================================================
|
||||||
|
![](http://www.omgubuntu.co.uk/wp-content/uploads/2015/04/synfig-free-animations-750x467.jpg)
|
||||||
|
|
||||||
|
**现在可以下载 Synfig Studio 这个自由、开源的2D动画软件的全新版本了。 **
|
||||||
|
|
||||||
|
在这个跨平台的软件首次发行一年之后,Synfig Studio 1.0 带着一套全新改进过的功能,实现它所承诺的“创造电影级的动画的工业级解决方案”。
|
||||||
|
|
||||||
|
在众多功能之上的是一个改进过的用户界面,据项目开发者说那是个用起来‘更简单’、‘更直观’的界面。客户端添加了新的**单窗口模式**,让界面更整洁,而且**使用了最新的 GTK3 库重制**。
|
||||||
|
|
||||||
|
在功能方面有几个值得注意的变化,包括新加的全功能骨骼系统。
|
||||||
|
|
||||||
|
这套**关节和转轴的‘骨骼’构架**非常适合2D剪纸动画,再配上这个版本新加的复杂的变形控制系统或是 Synfig 受欢迎的‘关键帧自动插入’(即:帧到帧之间的变形)应该会变得非常有效率的。(youtube视频 https://www.youtube.com/M8zW1qCq8ng )
|
||||||
|
|
||||||
|
新的无损剪切工具,摩擦力效果和对逐帧位图动画的支持,可能会有助于释放开源动画师们的创造力,更别说新加的用于同步动画的时间线和声音的声效层!
|
||||||
|
|
||||||
|
### 下载 Synfig Studio 1.0 ###
|
||||||
|
|
||||||
|
Synfig Studio 并不是任何人都能用的工具套件,这最新发行版的最新一批改进应该能吸引一些动画制作者试一试这个软件。
|
||||||
|
|
||||||
|
如果你想看看开源动画制作软件是什么样的,你可以通过下面的链接直接从工程的 Sourceforge 页下载一个适用于 Ubuntu 的最新版本的安装器。
|
||||||
|
|
||||||
|
- [下载 Synfig 1.0 (64bit) .deb 安装器][1]
|
||||||
|
- [下载 Synfig 1.0 (32bit) .deb 安装器][2]
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.omgubuntu.co.uk/2015/04/synfig-studio-new-release-features
|
||||||
|
|
||||||
|
作者:[Joey-Elijah Sneddon][a]
|
||||||
|
译者:[H-mudcup](https://github.com/H-mudcup)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:https://plus.google.com/117485690627814051450/?rel=author
|
||||||
|
[1]:http://sourceforge.net/projects/synfig/files/releases/1.0/linux/synfigstudio_1.0_amd64.deb/download
|
||||||
|
[2]:http://sourceforge.net/projects/synfig/files/releases/1.0/linux/synfigstudio_1.0_x86.deb/download
|
@ -0,0 +1,181 @@
|
|||||||
|
Web缓存基础:术语、HTTP报头和缓存策略
|
||||||
|
=====================================================================
|
||||||
|
|
||||||
|
### 简介
|
||||||
|
|
||||||
|
对于您的站点的访问者来说,智能化的内容缓存是提高用户体验最有效的方式之一。缓存,或者对之前的请求的临时存储,是HTTP协议实现中最核心的内容分发策略之一。分发路径中的组件均可以缓存内容来加速后续的请求,这受控于对该内容所声明的缓存策略。
|
||||||
|
|
||||||
|
在这份指南中,我们将讨论一些Web内容缓存的基本概念。这主要包括如何选择缓存策略以保证互联网范围内的缓存能够正确的处理您的内容。我们将谈一谈缓存带来的好处、副作用以及不同的策略能带来的性能和灵活性的最大结合。
|
||||||
|
|
||||||
|
###什么是缓存(caching)?
|
||||||
|
|
||||||
|
缓存(caching)是一个描述存储可重用资源以便加快后续请求的行为的术语。有许多不同类型的缓存,每种都有其自身的特点,应用程序缓存和内存缓存由于其对特定回复的加速,都很常用。
|
||||||
|
|
||||||
|
这份指南的主要讲述的Web缓存是一种不同类型的缓存。Web缓存是HTTP协议的一个核心特性,它能最小化网络流量,并且提升用户所感知的整个系统响应速度。内容从服务器到浏览器的传输过程中,每个层面都可以找到缓存的身影。
|
||||||
|
|
||||||
|
Web缓存根据特定的规则缓存相应HTTP请求的响应。对于缓存内容的后续请求便可以直接由缓存满足而不是重新发送请求到Web服务器。
|
||||||
|
|
||||||
|
###好处
|
||||||
|
|
||||||
|
有效的缓存技术不仅可以帮助用户,还可以帮助内容的提供者。缓存对内容分发带来的好处有:
|
||||||
|
|
||||||
|
- **减少网络开销**:内容可以在从内容提供者到内容消费者网络路径之间的许多不同的地方被缓存。当内容在距离内容消费者更近的地方被缓存时,由于缓存的存在,请求将不会消耗额外的网络资源。
|
||||||
|
- **加快响应速度**:由于并不是必须通过整个网络往返,缓存可以使内容的获得变得更快。缓存放在距用户更近的地方,例如浏览器缓存,使得内容的获取几乎是瞬时的。
|
||||||
|
- **在同样的硬件上提高速度**:对于保存原始内容的服务器来说,更多的性能可以通过允许激进的缓存策略从硬件上压榨出来。内容拥有者们可以利用分发路径上某个强大的服务器来应对特定内容负载的冲击。
|
||||||
|
- **网络中断时内容依旧可用**:使用某种策略,缓存可以保证在原始服务器变得不可用时,相应的内容对用户依旧可用。
|
||||||
|
|
||||||
|
###术语
|
||||||
|
|
||||||
|
在面对缓存时,您可能对一些经常遇到的术语可能不太熟悉。一些常见的术语如下:
|
||||||
|
|
||||||
|
- **原始服务器**:原始服务器是内容的原始存放地点。如果您是Web服务器管理员,它就是您所管理的机器。它负责为任何不能从缓存中得到的内容进行回复,并且负责设置所有内容的缓存策略。
|
||||||
|
- **缓存命中率**:一个缓存的有效性依照缓存的命中率进行度量。它是可以从缓存中得到数据的请求数与所有请求数的比率。缓存命中率高意味着有很高比例的数据可以从缓存中获得。这通常是大多数管理员想要的结果。
|
||||||
|
- **新鲜度**:新鲜度用来描述一个缓存中的项目是否依旧适合返回给客户端。缓存中的内容只有在由缓存策略指定的新鲜期内才会被返回。
|
||||||
|
- **过期内容**:缓存中根据缓存策略的新鲜期设置已过期的内容。过期的内容被标记为“陈旧”。通常,过期内容不能用于回复客户端的请求。必须重新从原始服务器请求新的内容或者至少验证缓存的内容是否仍然准确。
|
||||||
|
- **校验**:缓存中的过期内容可以验证是否有效以便刷新过期时间。验证过程包括联系原始服务器以检查缓存的数据是否依旧代表了最近的版本。
|
||||||
|
- **失效**:失效是依据过期日期从缓存中移除内容的过程。当内容在原始服务器上已被改变时就必须这样做,缓存中过期的内容会导致客户端发生问题。
|
||||||
|
|
||||||
|
还有许多其他的缓存术语,不过上面的这些应该能帮助您开始。
|
||||||
|
|
||||||
|
###什么能被缓存?
|
||||||
|
|
||||||
|
某些特定的内容比其他内容更容易被缓存。对大多数站点来说,一些适合缓存的内容如下:
|
||||||
|
|
||||||
|
- Logo和商标图像
|
||||||
|
- 普通的不变化的图像(例如,导航图标)
|
||||||
|
- CSS样式表
|
||||||
|
- 普通的Javascript文件
|
||||||
|
- 可下载的内容
|
||||||
|
- 媒体文件
|
||||||
|
|
||||||
|
这些文件更倾向于不经常改变,所以长时间的对它们进行缓存能获得好处。
|
||||||
|
|
||||||
|
一些项目在缓存中必须加以注意:
|
||||||
|
|
||||||
|
- HTML页面
|
||||||
|
- 会替换改变的图像
|
||||||
|
- 经常修改的Javascript和CSS文件
|
||||||
|
- 需要有认证后的cookies才能访问的内容
|
||||||
|
|
||||||
|
一些内容从来不应该被缓存:
|
||||||
|
|
||||||
|
- 与敏感信息相关的资源(银行数据,等)
|
||||||
|
- 用户相关且经常更改的数据
|
||||||
|
|
||||||
|
除上面的通用规则外,通常您需要指定一些规则以便于更好地缓存不同种类的内容。例如,如果登录的用户都看到的是同样的网站视图,就应该在任何地方缓存这个页面。如果登录的用户会在一段时间内看到站点中用户特定的视图,您应该让用户的浏览器缓存该数据而不应让任何中介节点缓存该视图。
|
||||||
|
|
||||||
|
###Web内容缓存的位置
|
||||||
|
|
||||||
|
Web内容会在整个分发路径中的许多不同的位置被缓存:
|
||||||
|
|
||||||
|
- **浏览器缓存**:Web浏览器自身会维护一个小型缓存。典型地,浏览器使用一种策略指示缓存最重要的内容。这可能是用户相关的内容或可能会再次请求且下载代价较高。
|
||||||
|
- **中间缓存代理**:任何在客户端和您的基础架构之间的服务器都可以按期望缓存一些内容。这些缓存可能由ISP(网络服务提供者)或者其他独立组织提供。
|
||||||
|
- **反向缓存**:您的服务器基础架构可以为后端的服务实现自己的缓存。如果实现了缓存,那么便可以在处理请求的位置返回相应的内容而不用每次请求都使用后端服务。
|
||||||
|
|
||||||
|
上面的这些位置通常都可以根据它们自身的缓存策略和内容源的缓存策略缓存一些相应的内容。
|
||||||
|
|
||||||
|
###缓存头部
|
||||||
|
|
||||||
|
缓存策略依赖于两个不同的因素。所缓存的实体本身需要决定是否应该缓存可接受的内容。它可以只缓存部分可以缓存的内容,但不能缓存超过限制的内容。
|
||||||
|
|
||||||
|
缓存行为主要由缓存策略决定,而缓存策略由内容拥有者设置。这些策略主要通过特定的HTTP头部来清晰地表达。
|
||||||
|
|
||||||
|
经过几个不同HTTP协议的变化,出现了一些不同的针对缓存方面的头部,它们的复杂度各不相同。下面列出了那些你也许应该注意的:
|
||||||
|
|
||||||
|
- **`Expires`**:尽管使用范围相当有限,但`Expires`头部是非常简洁明了的。通常它设置一个未来的时间,内容会在此时间过期。这时,任何对同样内容的请求都应该回到原始服务器处。这个头部或许仅仅最适合回退模式(fall back)。
|
||||||
|
- **`Cache-Control`**:这是`Expires`的一个更加现代化的替换物。它已被很好的支持,且拥有更加灵活的实现。在大多数案例中,它比`Expires`更好,但同时设置两者的值也无妨。稍后我们将讨论您可以设置的`Cache-Control`的详细选项。
|
||||||
|
- **`ETag`**:`ETag`用于缓存验证。源服务器可以在首次服务一个内容时为该内容提供一个独特的`ETag`。当一个缓存需要验证这个内容是否即将过期,他会将相应的`ETag`发送回服务器。源服务器或者告诉缓存内容是一致的,或者发送更新后的内容(带着新的`ETag`)。
|
||||||
|
- **`Last-Modified`**:这个头部指明了相应的内容最后一次被修改的时间。它可能会作为保证内容新鲜度的验证策略的一部分被使用。
|
||||||
|
- **`Content-Length`**:尽管并没有在缓存中明确涉及,`Content-Length`头部在设置缓存策略时很重要。某些软件如果不提前获知内容的大小以留出足够空间,则会拒绝缓存该内容。
|
||||||
|
- **`Vary`**:缓存系统通常使用请求的主机和路径作为存储该资源的键。当判断一个请求是否是请求同样内容时,`Vary`头部可以被用来提醒缓存系统需要注意另一个附加头部。它通常被用来告诉缓存系统同样注意`Accept-Encoding`头部,以便缓存系统能够区分压缩和未压缩的内容。
|
||||||
|
|
||||||
|
### Vary头部的隐语
|
||||||
|
|
||||||
|
`Vary`头部提供给您存储同一个内容的不同版本的能力,代价是降低了缓存的容量。
|
||||||
|
|
||||||
|
在使用`Accept-Encoding`时,设置`Vary`头部允许明确区分压缩和未压缩的内容。这在服务某些不能处理压缩数据的浏览器时很重要,它可以保证基本的可用性。`Vary`的一个典型的值是`Accept-Encoding`,它只有两到三个可选的值。
|
||||||
|
|
||||||
|
一开始看上去`User-Agent`这样的头部可以用于区分移动浏览器和桌面浏览器,以便您的站点提供差异化的服务。但`User-Agent`字符串是非标准的,结果将会造成在中间缓存中保存同一内容的许多不同版本的缓存,这会导致缓存命中率的降低。`Vary`头部应该谨慎使用,尤其是您不具备在您控制的中间缓存中使请求标准化的能力(也许可以,比如您可以控制CDN的话)。
|
||||||
|
|
||||||
|
###缓存控制标志怎样影响缓存
|
||||||
|
|
||||||
|
上面我们提到了`Cache-Control`头部如何被用与现代缓存策略标准。能够通过这个头部设定许多不同的缓存指令,多个不同的指令通过逗号分隔。
|
||||||
|
|
||||||
|
一些您可以使用的指示内容缓存策略的`Cache-Control`的选项如下:
|
||||||
|
|
||||||
|
- **`no-cache`**:这个指令指示所有缓存的内容在新的请求到达时必须先重新验证,再发送给客户端。这条指令实际将内容立刻标记为过期的,但允许通过验证手段重新验证以避免重新下载整个内容。
|
||||||
|
- **`no-store`**:这条指令指示缓存的内容不能以任何方式被缓存。它适合在回复敏感信息时设置。
|
||||||
|
- **`public`**:它将内容标记为公有的,这意味着它能被浏览器和其他任何中间节点缓存。通常,对于使用了HTTP验证的请求,其回复被默认标记为`private`。`public`标记将会覆盖这个设置。
|
||||||
|
- **`private`**:它将内容标记为私有的。私有数据可以被用户的浏览器缓存,但*不能*被任何中间节点缓存。它通常用于用户相关的数据。
|
||||||
|
- **`max-age`**:这个设置指示了缓存内容的最大生存期,它在最大生存期后必须在源服务器处被验证或被重新下载。在现代浏览器中这个选项大体上取代了`Expires`头部,浏览器也将其作为决定内容的新鲜度的基础。这个选项的值以秒为单位表示,最大可以表示一年的新鲜期(31536000秒)。
|
||||||
|
- **`s-maxage`**:这个选项非常类似于`max-age`,它指明了内容能够被缓存的时间。区别是这个选项只在中间节点的缓存中有效。结合这两个选项可以构建更加灵活的缓存策略。
|
||||||
|
- **`must-revalidate`**:它指明了由`max-age`、`s-maxage`或`Expires`头部指明的新鲜度信息必须被严格的遵守。它避免了缓存的数据在网络中断等类似的场景中被使用。
|
||||||
|
- **`proxy-revalidate`**:它和上面的选项有着一样的作用,但只应用于中间的代理节点。在这种情况下,用户的浏览器可以在网络中断时使用过期内容,但中间缓存内容不能用于此目的。
|
||||||
|
- **`no-transform`**:这个选项告诉缓存在任何情况下都不能因为性能的原因修改接收到的内容。这意味着,缓存不允许压缩接收到的内容(没有从原始服务器处接收过压缩版本的该内容)并发送。
|
||||||
|
|
||||||
|
这些选项能够以不同的方式结合以获得不同的缓存行为。一些互斥的值如下:
|
||||||
|
|
||||||
|
- `no-cache`,`no-store`以及由其他前面未提到的选项指明的常用的缓存行为
|
||||||
|
- `public`和`private`
|
||||||
|
|
||||||
|
如果`no-store`和`no-cache`都被设置,那么`no-store`会取代`no-cache`。对于非授权的请求的回复,`public`是隐含的设置。对于授权的请求的回复,`private`选项是隐含的。他们可以通过在`Cache-Control`头部中指明相应的相反的选项以覆盖。
|
||||||
|
|
||||||
|
###开发一种缓存策略
|
||||||
|
|
||||||
|
在理想情况下,任何内容都可以被尽可能缓存,而您的服务器只需要偶尔的提供一些验证内容即可。但这在现实中很少发生,因此您应该尝试设置一些明智的缓存策略,以在长期缓存和站点改变的需求间达到平衡。
|
||||||
|
|
||||||
|
### 常见问题
|
||||||
|
|
||||||
|
在许多情况中,由于内容被产生的方式(如根据每个用户动态的产生)或者内容的特性(例如银行的敏感数据),这些内容不应该被缓存。另一些许多管理员在设置缓存时可能面对的问题是外部缓存的数据未过期,但新版本的数据已经产生。
|
||||||
|
|
||||||
|
这些都是经常遇到的问题,它们会影响缓存的性能和您提供的数据的准确性。然而,我们可以通过开发提前预见这些问题的缓存策略来缓解这些问题。
|
||||||
|
|
||||||
|
### 一般性建议
|
||||||
|
|
||||||
|
尽管您的实际情况会指导您选择的缓存策略,但是下面的建议能帮助您获得一些合理的决定。
|
||||||
|
|
||||||
|
在您担心使用哪一个特定的头部之前,有一些特定的步骤可以帮助您提高您的缓存命中率。一些建议如下:
|
||||||
|
|
||||||
|
- **为图像、CSS和共享的内容建立特定的文件夹**:将内容放到特定的文件夹内使得您可以方便的从您的站点中的任何页面引用这些内容。
|
||||||
|
- **使用同样的URL来表示同样的内容**:由于缓存使用内容请求中的主机名和路径作为键,因此应保证您的所有页面中的该内容的引用方式相同,前一个建议能让这点更加容易做到。
|
||||||
|
- **尽可能使用CSS图像拼接**:对于像图标和导航等内容,使用CSS图像拼接能够减少渲染您页面所需要的请求往返,并且允许对拼接缓存很长一段时间。
|
||||||
|
- **尽可能将主机脚本和外部资源本地化**:如果您使用Javascript脚本和其他外部资源,如果上游没有提供合适的缓存头部,那么您应考虑将这些内容放在您自己的服务器上。您应该注意上游的任何更新,以便更新本地的拷贝。
|
||||||
|
- **对缓存内容收集文件摘要**:静态的内容比如CSS和Javascript文件等通常比较适合收集文件摘要。这意味着为文件名增加一个独特的标志符(通常是这个文件的哈希值)可以在文件修改后绕开缓存保证新的内容被重新获取。有很多工具可以帮助您创建文件摘要并且修改HTML文档中的引用。
|
||||||
|
|
||||||
|
对于不同的文件正确地选择不同的头部这件事,下面的内容可以作为一般性的参考:
|
||||||
|
|
||||||
|
- **允许所有的缓存存储一般内容**:静态内容以及非用户相关的内容应该在分发链的所有节点被缓存。这使得中间节点可以将该内容回复给多个用户。
|
||||||
|
- **允许浏览器缓存用户相关的内容**:对于每个用户的数据,通常在用户自己的浏览器中缓存是可以被接受且有益的。缓存在用户自身的浏览器能够使得用户在接下来的浏览中能够瞬时读取,但这些内容不适合在任何中间代理节点缓存。
|
||||||
|
- **将时间敏感的内容作为特例**:如果您的数据是时间敏感的,那么相对上面两条参考,应该将这些数据作为特例,以保证过期的数据不会在关键的情况下被使用。例如,您的站点有一个购物车,它应该立刻反应购物车里面的物品。依据内容的特点,可以在`Cache-Control`头部中使用`no-cache`或`no-store`选项。
|
||||||
|
- **总是提供验证器**:验证器使得过期的内容可以无需重新下载而得到刷新。设置`ETag`和`Last-Modified`头部将允许缓存向原始服务器验证内容,并在内容未修改时刷新该内容新鲜度以减少负载。
|
||||||
|
- **对于支持的内容设置长的新鲜期**:为了更加有效的利用缓存,一些作为支持性的内容应该被设置较长的新鲜期。这通常比较适合图像和CSS等由用户请求用来渲染HTML页面的内容。和文件摘要一起,设置延长的新鲜期将允许缓存长时间的存储这些资源。如果资源发生改变,修改的文件摘要将会使缓存的数据无效并触发对新的内容的下载。那时,新的支持的内容会继续被缓存。
|
||||||
|
- **对父内容设置短的新鲜期**:为了使得前面的模式正常工作,容器类的内容应该相应的设置短的新鲜期,或者设置不全部缓存。这通常是在其他协助内容中使用的HTML页面。这个HTML页面将会被频繁的下载,使得它能快速的响应改变。支持性的内容因此可以被尽量缓存。
|
||||||
|
|
||||||
|
关键之处便在于达到平衡,一方面可以尽量的进行缓存,另一方面为未来保留当改变发生时从而改变整个内容的机会。您的站点应该同时具有:
|
||||||
|
|
||||||
|
- 尽量缓存的内容
|
||||||
|
- 拥有短的新鲜期的缓存内容,可以被重新验证
|
||||||
|
- 完全不被缓存的内容
|
||||||
|
|
||||||
|
这样做的目的便是将内容尽可能的移动到第一个分类(尽量缓存)中的同时,维持可以接受的缓存命中率。
|
||||||
|
|
||||||
|
结论
|
||||||
|
----
|
||||||
|
|
||||||
|
花时间确保您的站点使用了合适的缓存策略将对您的站点产生重要的影响。缓存使得您可以在保证服务同样内容的同时减少带宽的使用。您的服务器因此可以靠同样的硬件处理更多的流量。或许更重要的是,客户们能在您的网站中获得更快的体验,这会使得他们更愿意频繁的访问您的站点。尽管有效的Web缓存并不是银弹,但设置合适的缓存策略会使您以最小的代价获得可观的收获。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
via: https://www.digitalocean.com/community/tutorials/web-caching-basics-terminology-http-headers-and-caching-strategies
|
||||||
|
|
||||||
|
作者: [Justin Ellingwood](https://www.digitalocean.com/community/users/jellingwood)
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
推荐:[royaso](https://github.com/royaso)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,25 +1,26 @@
|
|||||||
Bodhi Linux引入Moksha桌面
|
Bodhi Linux 将引入 Moksha 桌面
|
||||||
================================================================================
|
================================================================================
|
||||||
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/05/Bodhi_Linux.jpg)
|
![](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/05/Bodhi_Linux.jpg)
|
||||||
|
|
||||||
基于Ubuntu的轻量级Linux发行版[Bodhi Linux][1]致力于构建其自家的桌面环境,这个全新桌面环境被称之为Moksha(梵文意为‘完全自由’)。Moksha将替换常用的[Enlightenment桌面环境][2]。
|
基于Ubuntu的轻量级Linux发行版[Bodhi Linux][1]致力于构建其自家的桌面环境,这个全新桌面环境被称之为Moksha(梵文意为‘完全自由’)。Moksha将替换其原来的[Enlightenment桌面环境][2]。
|
||||||
|
|
||||||
### 为何用Moksha替换Englightenment? ###
|
### 为何用Moksha替换Englightenment? ###
|
||||||
|
|
||||||
Bodhi Linux的Jeff Hoogland最近[表示][3]了他对新版Enlightenment的不满。直到E17,Enlightenment都十分稳定,并且能满足轻量级Linux的部署需求。而E18则到处都充满了问题,Bodhi Linux只好弃之不用了。
|
Bodhi Linux的Jeff Hoogland最近[表示][3]了他对新版Enlightenment的不满。直到E17,Enlightenment都十分稳定,并且能满足轻量级Linux的部署需求。而E18则到处都充满了问题,Bodhi Linux只好弃之不用了。
|
||||||
|
|
||||||
虽然最新的[Bodhi Linux 3.0发行版][4]仍然使用了E19作为其桌面(除传统模式外,这意味着,对于旧的硬件,仍然会使用E17),Jeff对E19也十分不满。他说道:
|
虽然最新的[Bodhi Linux 3.0发行版][4]仍然使用了E19作为其桌面(除传统模式外,这意味着,对于旧的硬件,仍然会使用E17),Jeff对E19也十分不满。他说道:
|
||||||
|
|
||||||
>除了性能问题外,对于我个人而言,E19并没有给我带来与E17下相同的工作流程,因为它移除了很多E17的特性。鉴于此,我不得不将我所有的3台Bodhi计算机桌面改成E17——这3台机器都是我高端的了。这不由得让我想到,我们还有多少现存的Bodhi用户也怀着和我同样的感受,所以,我[在我们的用户论坛上开启一个与此相关的讨论][5]。
|
> 除了性能问题外,对于我个人而言,E19并没有给我带来与E17下相同的工作流程,因为它移除了很多E17的特性。鉴于此,我不得不将我所有的3台Bodhi计算机桌面改成E17——这3台机器都是我高端的了。这不由得让我想到,我们还有多少现存的Bodhi用户也怀着和我同样的感受,所以,我[在我们的用户论坛上开启一个与此相关的讨论][5]。
|
||||||
|
|
||||||
### Moksha是E17桌面的延续 ###
|
### Moksha是E17桌面的延续 ###
|
||||||
|
|
||||||
Moksha将会是Bodhi所热衷的E17桌面的延续。Jeff进一步提到:
|
Moksha将会是Bodhi所热衷的E17桌面的延续。Jeff进一步提到:
|
||||||
>我们将从整合所有Bodhi修改开始。多年来我们一直都只是给源代码打补丁,并修复桌面所具有的问题。如果该工作完成,我们将开始移植一些E18和E19引入的更为有用的特性,最后,我们将引入一些我们认为会改善最终用户体验的东西。
|
|
||||||
|
> 我们将从整合所有Bodhi修改开始。多年来我们一直都只是给源代码打补丁,并修复桌面所带有的问题。如果该工作完成,我们将开始移植一些E18和E19引入的更为有用的特性,最后,我们将引入一些我们认为会改善最终用户体验的东西。
|
||||||
|
|
||||||
### Moksha何时发布? ###
|
### Moksha何时发布? ###
|
||||||
|
|
||||||
下一个Bodhi更新将会是Bodhi 3.1.0,就在今年八月。这个新版本将为所有其缺省ISO带来Moksha。让我们拭目以待,看看Moksha是否是一个好的决定。
|
下一个Bodhi更新将会是Bodhi 3.1.0,就在今年八月。这个新版本将为所有其默认安装镜像带来Moksha。让我们拭目以待,看看Moksha是否是一个好的决定。
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -27,7 +28,7 @@ via: http://itsfoss.com/bodhi-linux-introduces-moksha-desktop/
|
|||||||
|
|
||||||
作者:[Abhishek][a]
|
作者:[Abhishek][a]
|
||||||
译者:[GOLinux](https://github.com/GOLinux)
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,86 @@
|
|||||||
|
Linux 有问必答:如何在Ubuntu上配置网桥
|
||||||
|
===============================================================================
|
||||||
|
> **Question**: 我需要在我的Ubuntu主机上建立一个Linux网桥,共享一个网卡给其他一些虚拟主机或在主机上创建的容器。我目前正在Ubuntu上使用网络管理器(Network Manager),所以最好>能使用网络管理器来配置一个网桥。我该怎么做?
|
||||||
|
|
||||||
|
网桥是一个硬件装备,用来将两个或多个数据链路层(OSI七层模型中第二层)互联,以使得不同网段上的网络设备可以互相访问。当你想要互联一个主机里的多个虚拟机器或者以太接口时,就需要在Linux主机里有一个类似桥接的概念。这里使用的是一种软网桥。
|
||||||
|
|
||||||
|
有很多的方法来配置一个Linux网桥。举个例子,在一个无外接显示/键盘的服务器环境里,你可以使用[brct][1]手动地配置一个网桥。而在桌面环境下,在网络管理器里也支持网桥设置。那就让我们测试一下如何用网络管理器配置一个网桥吧。
|
||||||
|
|
||||||
|
### 要求 ###
|
||||||
|
|
||||||
|
为了避免[任何问题][2],建议你的网络管理器版本为0.9.9或者更高,它用在 Ubuntu 15.04或者更新的版本。
|
||||||
|
|
||||||
|
$ apt-cache show network-manager | grep Version
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
Version: 0.9.10.0-4ubuntu15.1
|
||||||
|
Version: 0.9.10.0-4ubuntu15
|
||||||
|
|
||||||
|
### 创建一个网桥 ###
|
||||||
|
|
||||||
|
使用网络管理器创建网桥最简单的方式就是通过nm-connection-editor。这款GUI(图形用户界面)的工具允许你傻瓜式地配置一个网桥。
|
||||||
|
|
||||||
|
首先,启动nm-connection-editor。
|
||||||
|
|
||||||
|
$ nm-connection-editor
|
||||||
|
|
||||||
|
该编辑器的窗口会显示给你一个列表,列出目前配置好的网络连接。点击右上角的“添加”按钮,创建一个网桥。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8781/17139502730_c3ca920f7f.jpg)
|
||||||
|
|
||||||
|
接下来,选择“Bridge”(网桥)作为连接类型。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8873/17301102406_4f75133391_z.jpg)
|
||||||
|
|
||||||
|
现在,开始配置网桥,包括它的名字和所桥接的连接。如果没有创建过其他网桥,那么默认的网桥接口会被命名为bridge0。
|
||||||
|
|
||||||
|
回顾一下,创建网桥的目的是为了通过网桥共享你的以太网卡接口,所以你需要添加以太网卡接口到网桥。在图形界面添加一个新的“桥接的连接”可以实现上述目的。点击“Add”按钮。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8876/17327069755_52f1d81f37_z.jpg)
|
||||||
|
|
||||||
|
选择“以太网”作为连接类型。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8832/17326664591_632a9001da_z.jpg)
|
||||||
|
|
||||||
|
在“设备的 MAC 地址”区域,选择你想要从属于网桥的接口。本例中,假设该接口是eth0。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8842/17140820559_07a661f30c_z.jpg)
|
||||||
|
|
||||||
|
点击“常规”标签,并且选中两个复选框,分别是“当其可用时自动连接到该网络”和“所有用户都可以连接到该网络”。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7776/17325199982_801290e172_z.jpg)
|
||||||
|
|
||||||
|
切换到“IPv4 设置”标签,为网桥配置DHCP或者是静态IP地址。注意,你应该为从属的以太网卡接口eth0使用相同的IPv4设定。本例中,我们假设eth0是用过DHCP配置的。因此,此处选择“自动(DHCP)”。如果eth0被指定了一个静态IP地址,那么你也应该指定相同的IP地址给网桥。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7737/17140820469_99955cf916_z.jpg)
|
||||||
|
|
||||||
|
最后,保存网桥的设置。
|
||||||
|
|
||||||
|
现在,你会看见一个新增的网桥连接被创建在“网络连接”窗口里。因为已经从属与网桥,以前配置好的有线连接 eth0 就不再需要了,所以去删除原来的有线连接吧。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8700/17140820439_272a6d5c4e.jpg)
|
||||||
|
|
||||||
|
这时候,网桥连接会被自动激活。从指定给eth0的IP地址被网桥接管起,你将会暂时丢失一下连接。当IP地址赋给了网桥,你将会通过网桥连接回你的以太网卡接口。你可以通过“Network”设置确认一下。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7742/17325199902_9ceb67ddc1_c.jpg)
|
||||||
|
|
||||||
|
同时,检查可用的接口。提醒一下,网桥接口必须已经取代了任何你的以太网卡接口拥有的IP地址。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7717/17327069605_6143f1bd6a_b.jpg)
|
||||||
|
|
||||||
|
就这么多了,现在,网桥已经可以用了。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://ask.xmodulo.com/configure-linux-bridge-network-manager-ubuntu.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[wi-cuckoo](https://github.com/wi-cuckoo)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://ask.xmodulo.com/author/nanni
|
||||||
|
[1]:http://xmodulo.com/how-to-configure-linux-bridge-interface.html
|
||||||
|
[2]:https://bugs.launchpad.net/ubuntu/+source/network-manager/+bug/1273201
|
@ -1,12 +1,11 @@
|
|||||||
Linux有问必答--如何安装autossh
|
Linux有问必答:如何安装autossh
|
||||||
================================================================================
|
================================================================================
|
||||||
> **提问**: 我打算在linux上安装autossh,我应该怎么做呢?
|
> **提问**: 我打算在linux上安装autossh,我应该怎么做呢?
|
||||||
|
|
||||||
[autossh][1] 是一款开源工具,可以帮助管理SSH会话,自动重连和停止转发流量。autossh会假定目标主机已经设定[无密码SSH登陆][2],以便autossh可以重连断开的SSH会话而不用用户操作。
|
[autossh][1] 是一款开源工具,可以帮助管理SSH会话、自动重连和停止转发流量。autossh会假定目标主机已经设定[无密码SSH登陆][2],以便autossh可以重连断开的SSH会话而不用用户操作。
|
||||||
|
|
||||||
只要你建立[反向SSH隧道][3]或者[挂载基于SSH的远程文件夹][4],autossh迟早会派上用场。基本上只要需要维持SSH会话,autossh肯定是有用的。
|
只要你建立[反向SSH隧道][3]或者[挂载基于SSH的远程文件夹][4],autossh迟早会派上用场。基本上只要需要维持SSH会话,autossh肯定是有用的。
|
||||||
|
|
||||||
|
|
||||||
![](https://farm8.staticflickr.com/7786/17150854870_63966e78bc_c.jpg)
|
![](https://farm8.staticflickr.com/7786/17150854870_63966e78bc_c.jpg)
|
||||||
|
|
||||||
下面有许多linux发行版autossh的安装方法。
|
下面有许多linux发行版autossh的安装方法。
|
||||||
@ -29,8 +28,7 @@ CentOS/RHEL 6 或早期版本, 需要开启第三库[Repoforge库][5], 然后才
|
|||||||
|
|
||||||
$ sudo yum install autossh
|
$ sudo yum install autossh
|
||||||
|
|
||||||
CentOS/RHEL 7以后,autossh 已经不在Repoforge库中. 你需要从源码编译安装(例子在下面).
|
CentOS/RHEL 7以后,autossh 已经不在Repoforge库中. 你需要从源码编译安装(例子在下面)。
|
||||||
|
|
||||||
|
|
||||||
### Arch Linux 系统 ###
|
### Arch Linux 系统 ###
|
||||||
|
|
||||||
@ -66,13 +64,13 @@ via: http://ask.xmodulo.com/install-autossh-linux.html
|
|||||||
|
|
||||||
作者:[Dan Nanni][a]
|
作者:[Dan Nanni][a]
|
||||||
译者:[Vic020/VicYu](http://vicyu.net)
|
译者:[Vic020/VicYu](http://vicyu.net)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
[a]:http://ask.xmodulo.com/author/nanni
|
[a]:http://ask.xmodulo.com/author/nanni
|
||||||
[1]:http://www.harding.motd.ca/autossh/
|
[1]:http://www.harding.motd.ca/autossh/
|
||||||
[2]:http://xmodulo.com/how-to-enable-ssh-login-without.html
|
[2]:https://linux.cn/article-5444-1.html
|
||||||
[3]:http://xmodulo.com/access-linux-server-behind-nat-reverse-ssh-tunnel.html
|
[3]:http://xmodulo.com/access-linux-server-behind-nat-reverse-ssh-tunnel.html
|
||||||
[4]:http://xmodulo.com/how-to-mount-remote-directory-over-ssh-on-linux.html
|
[4]:http://xmodulo.com/how-to-mount-remote-directory-over-ssh-on-linux.html
|
||||||
[5]:http://xmodulo.com/how-to-set-up-rpmforge-repoforge-repository-on-centos.html
|
[5]:http://xmodulo.com/how-to-set-up-rpmforge-repoforge-repository-on-centos.html
|
@ -1,34 +1,35 @@
|
|||||||
OpenSSL command line Root and Intermediate CA including OCSP, CRL and revocation
|
建立你自己的 CA 服务:OpenSSL 命令行 CA 操作快速指南
|
||||||
================================================================================
|
================================================================================
|
||||||
These are quick and dirty notes on generating a certificate authority (CA), intermediate certificate authorities and end certificates using OpenSSL. It includes OCSP, CRL and CA Issuer information and specific issue and expiry dates.
|
|
||||||
|
|
||||||
We'll set up our own root CA. We'll use the root CA to generate an example intermediate CA. We'll use the intermediate CA to sign end user certificates.
|
这些是关于使用 OpenSSL 生成证书授权(CA)、中间证书授权和末端证书的速记随笔,内容包括 OCSP、CRL 和 CA 颁发者信息,以及指定颁发和有效期限等。
|
||||||
|
|
||||||
### Root CA ###
|
我们将建立我们自己的根 CA,我们将使用根 CA 来生成一个中间 CA 的例子,我们将使用中间 CA 来签署末端用户证书。
|
||||||
|
|
||||||
Create and move in to a folder for the root ca:
|
### 根 CA ###
|
||||||
|
|
||||||
|
创建根 CA 授权目录并切换到该目录:
|
||||||
|
|
||||||
mkdir ~/SSLCA/root/
|
mkdir ~/SSLCA/root/
|
||||||
cd ~/SSLCA/root/
|
cd ~/SSLCA/root/
|
||||||
|
|
||||||
Generate a 8192-bit long SHA-256 RSA key for our root CA:
|
为我们的根 CA 生成一个8192位长的 SHA-256 RSA 密钥:
|
||||||
|
|
||||||
openssl genrsa -aes256 -out rootca.key 8192
|
openssl genrsa -aes256 -out rootca.key 8192
|
||||||
|
|
||||||
Example output:
|
样例输出:
|
||||||
|
|
||||||
Generating RSA private key, 8192 bit long modulus
|
Generating RSA private key, 8192 bit long modulus
|
||||||
.........++
|
.........++
|
||||||
....................................................................................................................++
|
....................................................................................................................++
|
||||||
e is 65537 (0x10001)
|
e is 65537 (0x10001)
|
||||||
|
|
||||||
If you want to password-protect this key, add the option `-aes256`.
|
如果你想要用密码保护该密钥,请添加 `-aes256` 选项。
|
||||||
|
|
||||||
Create the self-signed root CA certificate `ca.crt`; you'll need to provide an identity for your root CA:
|
创建自签名根 CA 证书 `ca.crt`;你需要为你的根 CA 提供一个身份:
|
||||||
|
|
||||||
openssl req -sha256 -new -x509 -days 1826 -key rootca.key -out rootca.crt
|
openssl req -sha256 -new -x509 -days 1826 -key rootca.key -out rootca.crt
|
||||||
|
|
||||||
Example output:
|
样例输出:
|
||||||
|
|
||||||
You are about to be asked to enter information that will be incorporated
|
You are about to be asked to enter information that will be incorporated
|
||||||
into your certificate request.
|
into your certificate request.
|
||||||
@ -45,13 +46,13 @@ Example output:
|
|||||||
Common Name (e.g. server FQDN or YOUR name) []:Sparkling Root CA
|
Common Name (e.g. server FQDN or YOUR name) []:Sparkling Root CA
|
||||||
Email Address []:
|
Email Address []:
|
||||||
|
|
||||||
Create a few files where the CA will store it's serials:
|
创建一个存储 CA 序列的文件:
|
||||||
|
|
||||||
touch certindex
|
touch certindex
|
||||||
echo 1000 > certserial
|
echo 1000 > certserial
|
||||||
echo 1000 > crlnumber
|
echo 1000 > crlnumber
|
||||||
|
|
||||||
Place the CA config file. This file has stubs for CRL and OCSP endpoints.
|
放置 CA 配置文件,该文件持有 CRL 和 OCSP 末端的存根。
|
||||||
|
|
||||||
# vim ca.conf
|
# vim ca.conf
|
||||||
[ ca ]
|
[ ca ]
|
||||||
@ -120,23 +121,23 @@ Place the CA config file. This file has stubs for CRL and OCSP endpoints.
|
|||||||
OCSP;URI.0 = http://pki.sparklingca.com/ocsp/
|
OCSP;URI.0 = http://pki.sparklingca.com/ocsp/
|
||||||
OCSP;URI.1 = http://pki.backup.com/ocsp/
|
OCSP;URI.1 = http://pki.backup.com/ocsp/
|
||||||
|
|
||||||
If you need to set a specific certificate start / expiry date, add the following to `[myca]`
|
如果你需要设置某个特定的证书生效/过期日期,请添加以下内容到`[myca]`:
|
||||||
|
|
||||||
# format: YYYYMMDDHHMMSS
|
# format: YYYYMMDDHHMMSS
|
||||||
default_enddate = 20191222035911
|
default_enddate = 20191222035911
|
||||||
default_startdate = 20181222035911
|
default_startdate = 20181222035911
|
||||||
|
|
||||||
### Creating Intermediate 1 CA ###
|
### 创建中间 CA###
|
||||||
|
|
||||||
Generate the intermediate CA's private key:
|
生成中间 CA (名为 intermediate1)的私钥:
|
||||||
|
|
||||||
openssl genrsa -out intermediate1.key 4096
|
openssl genrsa -out intermediate1.key 4096
|
||||||
|
|
||||||
Generate the intermediate1 CA's CSR:
|
生成中间 CA 的 CSR:
|
||||||
|
|
||||||
openssl req -new -sha256 -key intermediate1.key -out intermediate1.csr
|
openssl req -new -sha256 -key intermediate1.key -out intermediate1.csr
|
||||||
|
|
||||||
Example output:
|
样例输出:
|
||||||
|
|
||||||
You are about to be asked to enter information that will be incorporated
|
You are about to be asked to enter information that will be incorporated
|
||||||
into your certificate request.
|
into your certificate request.
|
||||||
@ -158,13 +159,13 @@ Example output:
|
|||||||
A challenge password []:
|
A challenge password []:
|
||||||
An optional company name []:
|
An optional company name []:
|
||||||
|
|
||||||
Make sure the subject (CN) of the intermediate is different from the root.
|
确保中间 CA 的主体(CN)和根 CA 不同。
|
||||||
|
|
||||||
Sign the intermediate1 CSR with the Root CA:
|
用根 CA 签署 中间 CA 的 CSR:
|
||||||
|
|
||||||
openssl ca -batch -config ca.conf -notext -in intermediate1.csr -out intermediate1.crt
|
openssl ca -batch -config ca.conf -notext -in intermediate1.csr -out intermediate1.crt
|
||||||
|
|
||||||
Example Output:
|
样例输出:
|
||||||
|
|
||||||
Using configuration from ca.conf
|
Using configuration from ca.conf
|
||||||
Check that the request matches the signature
|
Check that the request matches the signature
|
||||||
@ -181,37 +182,37 @@ Example Output:
|
|||||||
Write out database with 1 new entries
|
Write out database with 1 new entries
|
||||||
Data Base Updated
|
Data Base Updated
|
||||||
|
|
||||||
Generate the CRL (both in PEM and DER):
|
生成 CRL(同时采用 PEM 和 DER 格式):
|
||||||
|
|
||||||
openssl ca -config ca.conf -gencrl -keyfile rootca.key -cert rootca.crt -out rootca.crl.pem
|
openssl ca -config ca.conf -gencrl -keyfile rootca.key -cert rootca.crt -out rootca.crl.pem
|
||||||
|
|
||||||
openssl crl -inform PEM -in rootca.crl.pem -outform DER -out rootca.crl
|
openssl crl -inform PEM -in rootca.crl.pem -outform DER -out rootca.crl
|
||||||
|
|
||||||
Generate the CRL after every certificate you sign with the CA.
|
每次使用该 CA 签署证书后,请生成 CRL。
|
||||||
|
|
||||||
If you ever need to revoke the this intermediate cert:
|
如果你需要撤销该中间证书:
|
||||||
|
|
||||||
openssl ca -config ca.conf -revoke intermediate1.crt -keyfile rootca.key -cert rootca.crt
|
openssl ca -config ca.conf -revoke intermediate1.crt -keyfile rootca.key -cert rootca.crt
|
||||||
|
|
||||||
### Configuring the Intermediate CA 1 ###
|
### 配置中间 CA ###
|
||||||
|
|
||||||
Create a new folder for this intermediate and move in to it:
|
为该中间 CA 创建一个新文件夹,然后进入该文件夹:
|
||||||
|
|
||||||
mkdir ~/SSLCA/intermediate1/
|
mkdir ~/SSLCA/intermediate1/
|
||||||
cd ~/SSLCA/intermediate1/
|
cd ~/SSLCA/intermediate1/
|
||||||
|
|
||||||
Copy the Intermediate cert and key from the Root CA:
|
从根 CA 拷贝中间证书和密钥:
|
||||||
|
|
||||||
cp ~/SSLCA/root/intermediate1.key ./
|
cp ~/SSLCA/root/intermediate1.key ./
|
||||||
cp ~/SSLCA/root/intermediate1.crt ./
|
cp ~/SSLCA/root/intermediate1.crt ./
|
||||||
|
|
||||||
Create the index files:
|
创建索引文件:
|
||||||
|
|
||||||
touch certindex
|
touch certindex
|
||||||
echo 1000 > certserial
|
echo 1000 > certserial
|
||||||
echo 1000 > crlnumber
|
echo 1000 > crlnumber
|
||||||
|
|
||||||
Create a new `ca.conf` file:
|
创建一个新的 `ca.conf` 文件:
|
||||||
|
|
||||||
# vim ca.conf
|
# vim ca.conf
|
||||||
[ ca ]
|
[ ca ]
|
||||||
@ -269,35 +270,35 @@ Create a new `ca.conf` file:
|
|||||||
OCSP;URI.0 = http://pki.sparklingca.com/ocsp/
|
OCSP;URI.0 = http://pki.sparklingca.com/ocsp/
|
||||||
OCSP;URI.1 = http://pki.backup.com/ocsp/
|
OCSP;URI.1 = http://pki.backup.com/ocsp/
|
||||||
|
|
||||||
Change the `[alt_names]` section to whatever you need as Subject Alternative names. Remove it including the `subjectAltName = @alt_names` line if you don't want a Subject Alternative Name.
|
修改 `[alt_names]` 部分,添加你需要的主体备选名。如果你不需要主体备选名,请移除该部分包括`subjectAltName = @alt_names`的行。
|
||||||
|
|
||||||
If you need to set a specific certificate start / expiry date, add the following to `[myca]`
|
如果你需要设置一个指定的生效/到期日期,请添加以下内容到 `[myca]`:
|
||||||
|
|
||||||
# format: YYYYMMDDHHMMSS
|
# format: YYYYMMDDHHMMSS
|
||||||
default_enddate = 20191222035911
|
default_enddate = 20191222035911
|
||||||
default_startdate = 20181222035911
|
default_startdate = 20181222035911
|
||||||
|
|
||||||
Generate an empty CRL (both in PEM and DER):
|
生成一个空白 CRL(同时以 PEM 和 DER 格式):
|
||||||
|
|
||||||
openssl ca -config ca.conf -gencrl -keyfile rootca.key -cert rootca.crt -out rootca.crl.pem
|
openssl ca -config ca.conf -gencrl -keyfile rootca.key -cert rootca.crt -out rootca.crl.pem
|
||||||
|
|
||||||
openssl crl -inform PEM -in rootca.crl.pem -outform DER -out rootca.crl
|
openssl crl -inform PEM -in rootca.crl.pem -outform DER -out rootca.crl
|
||||||
|
|
||||||
### Creating end user certificates ###
|
### 生成末端用户证书 ###
|
||||||
|
|
||||||
We use this new intermediate CA to generate an end user certificate. Repeat these steps for every end user certificate you want to sign with this CA.
|
我们使用这个新的中间 CA 来生成一个末端用户证书,请重复以下操作来使用该 CA 为每个用户签署。
|
||||||
|
|
||||||
mkdir enduser-certs
|
mkdir enduser-certs
|
||||||
|
|
||||||
Generate the end user's private key:
|
生成末端用户的私钥:
|
||||||
|
|
||||||
openssl genrsa -out enduser-certs/enduser-example.com.key 4096
|
openssl genrsa -out enduser-certs/enduser-example.com.key 4096
|
||||||
|
|
||||||
Generate the end user's CSR:
|
生成末端用户的 CSR:
|
||||||
|
|
||||||
openssl req -new -sha256 -key enduser-certs/enduser-example.com.key -out enduser-certs/enduser-example.com.csr
|
openssl req -new -sha256 -key enduser-certs/enduser-example.com.key -out enduser-certs/enduser-example.com.csr
|
||||||
|
|
||||||
Example output:
|
样例输出:
|
||||||
|
|
||||||
You are about to be asked to enter information that will be incorporated
|
You are about to be asked to enter information that will be incorporated
|
||||||
into your certificate request.
|
into your certificate request.
|
||||||
@ -319,11 +320,11 @@ Example output:
|
|||||||
A challenge password []:
|
A challenge password []:
|
||||||
An optional company name []:
|
An optional company name []:
|
||||||
|
|
||||||
Sign the end user's CSR with the Intermediate 1 CA:
|
使用中间 CA 签署末端用户的 CSR:
|
||||||
|
|
||||||
openssl ca -batch -config ca.conf -notext -in enduser-certs/enduser-example.com.csr -out enduser-certs/enduser-example.com.crt
|
openssl ca -batch -config ca.conf -notext -in enduser-certs/enduser-example.com.csr -out enduser-certs/enduser-example.com.crt
|
||||||
|
|
||||||
Example output:
|
样例输出:
|
||||||
|
|
||||||
Using configuration from ca.conf
|
Using configuration from ca.conf
|
||||||
Check that the request matches the signature
|
Check that the request matches the signature
|
||||||
@ -340,56 +341,56 @@ Example output:
|
|||||||
Write out database with 1 new entries
|
Write out database with 1 new entries
|
||||||
Data Base Updated
|
Data Base Updated
|
||||||
|
|
||||||
Generate the CRL (both in PEM and DER):
|
生成 CRL(同时以 PEM 和 DER 格式):
|
||||||
|
|
||||||
openssl ca -config ca.conf -gencrl -keyfile intermediate1.key -cert intermediate1.crt -out intermediate1.crl.pem
|
openssl ca -config ca.conf -gencrl -keyfile intermediate1.key -cert intermediate1.crt -out intermediate1.crl.pem
|
||||||
|
|
||||||
openssl crl -inform PEM -in intermediate1.crl.pem -outform DER -out intermediate1.crl
|
openssl crl -inform PEM -in intermediate1.crl.pem -outform DER -out intermediate1.crl
|
||||||
|
|
||||||
Generate the CRL after every certificate you sign with the CA.
|
每次你使用该 CA 签署证书后,都需要生成 CRL。
|
||||||
|
|
||||||
If you ever need to revoke the this end users cert:
|
如果你需要撤销该末端用户证书:
|
||||||
|
|
||||||
openssl ca -config ca.conf -revoke enduser-certs/enduser-example.com.crt -keyfile intermediate1.key -cert intermediate1.crt
|
openssl ca -config ca.conf -revoke enduser-certs/enduser-example.com.crt -keyfile intermediate1.key -cert intermediate1.crt
|
||||||
|
|
||||||
Example output:
|
样例输出:
|
||||||
|
|
||||||
Using configuration from ca.conf
|
Using configuration from ca.conf
|
||||||
Revoking Certificate 1000.
|
Revoking Certificate 1000.
|
||||||
Data Base Updated
|
Data Base Updated
|
||||||
|
|
||||||
Create the certificate chain file by concatenating the Root and intermediate 1 certificates together.
|
通过连接根证书和中间证书来创建证书链文件。
|
||||||
|
|
||||||
cat ../root/rootca.crt intermediate1.crt > enduser-certs/enduser-example.com.chain
|
cat ../root/rootca.crt intermediate1.crt > enduser-certs/enduser-example.com.chain
|
||||||
|
|
||||||
Send the following files to the end user:
|
发送以下文件给末端用户:
|
||||||
|
|
||||||
enduser-example.com.crt
|
enduser-example.com.crt
|
||||||
enduser-example.com.key
|
enduser-example.com.key
|
||||||
enduser-example.com.chain
|
enduser-example.com.chain
|
||||||
|
|
||||||
You can also let the end user supply their own CSR and just send them the .crt file. Do not delete that from the server, otherwise you cannot revoke it.
|
你也可以让末端用户提供他们自己的 CSR,而只发送给他们这个 .crt 文件。不要把它从服务器删除,否则你就不能撤销了。
|
||||||
|
|
||||||
### Validating the certificate ###
|
### 校验证书 ###
|
||||||
|
|
||||||
You can validate the end user certificate against the chain using the following command:
|
你可以对证书链使用以下命令来验证末端用户证书:
|
||||||
|
|
||||||
openssl verify -CAfile enduser-certs/enduser-example.com.chain enduser-certs/enduser-example.com.crt
|
openssl verify -CAfile enduser-certs/enduser-example.com.chain enduser-certs/enduser-example.com.crt
|
||||||
enduser-certs/enduser-example.com.crt: OK
|
enduser-certs/enduser-example.com.crt: OK
|
||||||
|
|
||||||
You can also validate it against the CRL. Concatenate the PEM CRL and the chain together first:
|
你也可以针对 CRL 来验证。首先,将 PEM 格式的 CRL 和证书链相连接:
|
||||||
|
|
||||||
cat ../root/rootca.crt intermediate1.crt intermediate1.crl.pem > enduser-certs/enduser-example.com.crl.chain
|
cat ../root/rootca.crt intermediate1.crt intermediate1.crl.pem > enduser-certs/enduser-example.com.crl.chain
|
||||||
|
|
||||||
Verify the certificate:
|
验证证书:
|
||||||
|
|
||||||
openssl verify -crl_check -CAfile enduser-certs/enduser-example.com.crl.chain enduser-certs/enduser-example.com.crt
|
openssl verify -crl_check -CAfile enduser-certs/enduser-example.com.crl.chain enduser-certs/enduser-example.com.crt
|
||||||
|
|
||||||
Output when not revoked:
|
没有撤销时的输出:
|
||||||
|
|
||||||
enduser-certs/enduser-example.com.crt: OK
|
enduser-certs/enduser-example.com.crt: OK
|
||||||
|
|
||||||
Output when revoked:
|
撤销后的输出如下:
|
||||||
|
|
||||||
enduser-certs/enduser-example.com.crt: CN = example.com, ST = Noord Holland, C = NL, O = Example Inc, OU = IT Dept
|
enduser-certs/enduser-example.com.crt: CN = example.com, ST = Noord Holland, C = NL, O = Example Inc, OU = IT Dept
|
||||||
error 23 at 0 depth lookup:certificate revoked
|
error 23 at 0 depth lookup:certificate revoked
|
||||||
@ -399,7 +400,7 @@ Output when revoked:
|
|||||||
via: https://raymii.org/s/tutorials/OpenSSL_command_line_Root_and_Intermediate_CA_including_OCSP_CRL%20and_revocation.html
|
via: https://raymii.org/s/tutorials/OpenSSL_command_line_Root_and_Intermediate_CA_including_OCSP_CRL%20and_revocation.html
|
||||||
|
|
||||||
作者:Remy van Elst
|
作者:Remy van Elst
|
||||||
译者:[译者ID](https://github.com/译者ID)
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
@ -0,0 +1,121 @@
|
|||||||
|
一个用于Gnome桌面的下拉式终端: Guake 0.7.0 发布
|
||||||
|
================================================================================
|
||||||
|
Linux的命令行是最好、最强大的东西,它使新手着迷,并为老手和极客的提供极其强大的功能。那些在服务器和生产环境下工作的人早已认识到了这个事实。有趣的是,Linux终端是Linus Torvald在1991年写内核时实现的第一批功能之一。
|
||||||
|
|
||||||
|
终端是个强大的工具,由于它没有什么可调整的部分,所以十分可靠。终端介于控制台环境和GUI环境之间。终端自身作为一个GUI程序,运行在桌面环境下。有许多终端是适用于特定的桌面环境的,其它的则是通用的。Terminator, Konsole, Gnome-Terminal, Terminology, XFCE terminal, xterm都是些常用的终端模拟器。
|
||||||
|
|
||||||
|
您可以从下面的链接中获得一份使用最广泛的终端模拟器的列表。
|
||||||
|
|
||||||
|
- [20 Useful Terminals for Linux][1]
|
||||||
|
|
||||||
|
前几日上网时,我偶遇了名为‘Guake’的终端程序,它是用于gnome的终端模拟器。尽管这并不是我第一次听到Guake。实际上,我在大约一年前便知道了这个应用程序,但不知怎么搞的,我那时没有写写Guake,再后来我便渐渐忘掉了Guake,直到我再一次听到Guake。所以,最终,这篇文章诞生了。我将给你讲讲Guake的功能,在Debian、Ubuntu、Fedora上的安装过程以及一些测试。
|
||||||
|
|
||||||
|
#### 什么是Guake? ####
|
||||||
|
|
||||||
|
Guake是应用于Gnome环境的下拉式终端。主要由Python编写,使用了一些C,它以GPL2+许可证发布,适用于Linux以及类似的系统。Guake的灵感来源于电脑游戏Quake(雷神之锤)中的终端,Quake的终端能通过按下特定按键(默认为F12)从屏幕上滑下来,并在按下同样的键后滑上去。
|
||||||
|
|
||||||
|
值得注意的是,Guake并不是第一个这样的应用。Yakuake(Yet Another Kuake)是一个运行于KDE的终端模拟器,Tilda是一个用GTK+写成的终端模拟器。它们的灵感都来自于雷神之锤那上下滑动的终端。
|
||||||
|
|
||||||
|
#### Guake的功能 ####
|
||||||
|
|
||||||
|
- 轻量级
|
||||||
|
- 简单而优雅
|
||||||
|
- 功能众多
|
||||||
|
- 强大
|
||||||
|
- 美观
|
||||||
|
- 将终端平滑地集成于GUI中
|
||||||
|
- 在按下预定义的键后出现/消失
|
||||||
|
- 支持热键、标签、透明化背景,这使得它适合所有Gnome用户
|
||||||
|
- 可配置各种方面
|
||||||
|
- 包括许多颜色的调色板
|
||||||
|
- 设定透明度的快捷方式
|
||||||
|
- 通过Guake配置,可在启动时运行一个脚本
|
||||||
|
- 可以在多个显示器上运行
|
||||||
|
|
||||||
|
Guake 0.7.0最近发布,它带来了一些修正以及上面提到的一些功能。完整的版本历史和源代码包可以在[这里][2]找到。
|
||||||
|
|
||||||
|
### 在Linux中安装Guake终端 ###
|
||||||
|
|
||||||
|
如果您对从源码编译Guake感兴趣,您可以从上面的链接处下载Guake,并在安装前进行编译。
|
||||||
|
|
||||||
|
然而Guake可以在许多的发行版中通过添加额外的仓库来安装。这里,我们将在Debian、Ubuntu、Linux Mint和Fedora下安装Guake。
|
||||||
|
|
||||||
|
首先从仓库获取最新的软件包列表,并从默认的仓库安装Guake,如下所示:
|
||||||
|
|
||||||
|
---------------- 在 Debian, Ubuntu 和 Linux Mint 上 ----------------
|
||||||
|
$ sudo apt-get update
|
||||||
|
$ apt-get install guake
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
---------------- 在 Fedora 19 及其以后版本 ----------------
|
||||||
|
# yum update
|
||||||
|
# yum install guake
|
||||||
|
|
||||||
|
安装后,可以从另一个终端中启动Guake:
|
||||||
|
|
||||||
|
$ guake
|
||||||
|
|
||||||
|
在启动它后,便可以在Gnome桌面中使用F12(默认配置)来拉下、收回终端。
|
||||||
|
|
||||||
|
看起来非常漂亮,尤其是透明背景。滑下来...滑上去...滑下来...滑上去...执行命令,打开另一个标签,执行命令,滑上去...滑下来...(作者已沉迷其中)
|
||||||
|
|
||||||
|
![Guake Terminal in Action](http://www.tecmint.com/wp-content/uploads/2015/05/Guake.png)
|
||||||
|
|
||||||
|
*Guake实战*
|
||||||
|
|
||||||
|
如果您的壁纸或活动窗口的颜色和Guake的颜色有些不搭。您可以改变您的壁纸,减少透明度或者改变Guake的颜色。
|
||||||
|
|
||||||
|
下一步便是进入Guake的配置,根据每个人的需求修改设置。可以通过应用菜单或者下面的命令来运行Guake的配置。
|
||||||
|
|
||||||
|
$ guake --preferences
|
||||||
|
|
||||||
|
![Guake Terminal Properties](http://www.tecmint.com/wp-content/uploads/2015/05/Guake-Properties.png)
|
||||||
|
|
||||||
|
*Guake终端配置*
|
||||||
|
|
||||||
|
设置滚动
|
||||||
|
|
||||||
|
![Guake Scrolling Settings](http://www.tecmint.com/wp-content/uploads/2015/05/Guake-Scrolling.png)
|
||||||
|
|
||||||
|
*Guake滚动配置*
|
||||||
|
|
||||||
|
外观设置 - 在这里您可以修改文字颜色和背景色以及透明度。
|
||||||
|
|
||||||
|
![Appearance Properties](http://www.tecmint.com/wp-content/uploads/2015/05/Appearance-Properties.png)
|
||||||
|
|
||||||
|
*外观设置*
|
||||||
|
|
||||||
|
键盘快捷键 - 在这里您可以修改Guake显示的开关快捷键。
|
||||||
|
|
||||||
|
![Keyboard Shortcuts](http://www.tecmint.com/wp-content/uploads/2015/05/Keyboard-Shortcuts.png)
|
||||||
|
|
||||||
|
*键盘快捷键*
|
||||||
|
|
||||||
|
兼容性设置 - 基本上不必设置它。
|
||||||
|
|
||||||
|
![Compatibility Setting](http://www.tecmint.com/wp-content/uploads/2015/05/Compatibility-Setting.png)
|
||||||
|
|
||||||
|
*兼容性设置*
|
||||||
|
|
||||||
|
### 结论 ###
|
||||||
|
|
||||||
|
这个项目即不是太年轻也不是太古老,因此它已经达到了一定的成熟度,足够可靠,可以开箱即用。像我这样需要在GUI和终端间频繁切换的人来说,Guake是一个福利。我不需要管理一个多余的窗口,频繁的打开和关闭,使用tab在大量打开的应用程序中寻找终端或切换到不同的工作区来管理终端,现在我需要的只有F12。
|
||||||
|
|
||||||
|
我认为对任何同时使用GUI和终端的Linux用户来说,Guake都是必须的工具。同样的,我会向任何想要在系统中结合使用GUI和终端的人推荐它,因为它既平滑又没有任何障碍。
|
||||||
|
|
||||||
|
上面就是我要说的全部了。如果在安装和使用时有任何问题,请告诉我,我们会帮助您。也请您告诉我您使用Guake的经验。在下面的评论区反馈您宝贵的经验。点赞和分享以帮助我们宣传。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.tecmint.com/install-guake-terminal-ubuntu-mint-fedora/
|
||||||
|
|
||||||
|
作者:[Avishek Kumar][a]
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.tecmint.com/author/avishek/
|
||||||
|
[1]:http://www.tecmint.com/linux-terminal-emulators/
|
||||||
|
[2]:https://github.com/Guake/guake/releases/tag/0.7.0
|
@ -0,0 +1,105 @@
|
|||||||
|
初来乍到Linux? 你需要知道的5款好应用
|
||||||
|
================================================================================
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/05/linux-apps-840x420.jpg?92a7a3)
|
||||||
|
|
||||||
|
当你刚刚迈入linux的世界时,你会立马动身开始使用那些知名的浏览器、云客户端、音乐播放器、邮件客户端,也许还有图形编辑器,对吗?可是,你却错过了几个非常重要的生产工具。这里将介绍给你5个应该安装的不容错过的应用。
|
||||||
|
|
||||||
|
### [Synergy][1] ###
|
||||||
|
|
||||||
|
Synergy 简直就是多桌面用户的福音。这是一个开源软件,它可以让你用一个鼠标和键盘跨越几台电脑、显示器和操作系统。在桌面之间切换鼠标和键盘非常简单,你只要把鼠标从一个桌面的边缘移向另一个桌面即可。
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/multiple-monitors-640x431.jpg?92a7a3)
|
||||||
|
|
||||||
|
当你第一次打开 Synergy,它会引导你完成设置。你的主桌面就是你将与其它桌面共享输入设备的那个。将主桌面设为服务端,将其它桌面设置为客户端。
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/synergy-setup-wizard-640x480.jpg?92a7a3)
|
||||||
|
|
||||||
|
Synergy 在互连的各个桌面间维持同一张粘贴板。它也将锁屏功能融合到了一起,例如,你可以跳过锁屏一次登录到所有桌面。你可以在 **Edit 菜单的 Setting** 下调整更多的设置,比如设置密码或者将 Synergy 设置成开机自启动。
|
||||||
|
|
||||||
|
(LCTT 译注:这是个[自由而开源][15]的好软件,但是如果你从它的网站下载,由于商业支持的缘故,是需要付费的;当然你可以自己[下载源代码并编译][15]。)
|
||||||
|
|
||||||
|
### [BasKet Note Pads][2] ###
|
||||||
|
|
||||||
|
从某种意义上来讲,用 BasKet Note Pads,就像把你的大脑刻画进计算机里一样。它把我们不经意间的想法记录下来,然后任由我们去把它们组织起来。你可以在各种任务中用到 BasKet Note Pads,比如记录笔记、制作脑图、记录代办事项、保存链接、管理你的发现、或者追踪项目数据。
|
||||||
|
|
||||||
|
在 BasKet Note Pads 中,每个放到一个区域的主要的想法或项目被称作一个篮子(basket)。你可以进一步拆分,成一个或多个子篮或者兄弟篮。篮子进一步分成笔记,这些零零碎碎的笔记组成了一个项目。你可以自由组织它们,给它们打标签,和筛选它们。
|
||||||
|
|
||||||
|
该应用的双面板结构的左侧以树形结构显示了你创建的所有篮子。
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/basket-note-pads-640x480.jpg?92a7a3)
|
||||||
|
|
||||||
|
BasKet Note Pads 第一次用起来可能有点复杂,但是如果你经常用它的话,你会觉得相当顺手。当你暂时不用它时,它会退出到系统托盘,方便你下次快速打开它。
|
||||||
|
|
||||||
|
如果在 Linux 上想要一个[更简单的笔记本替代品][3]?可以试试[Springseed][4]。
|
||||||
|
|
||||||
|
### [Caffeine(咖啡因)][5]###
|
||||||
|
|
||||||
|
你怎样确保你的电脑不会在放一部[精彩的电影][6]中途突然休眠呢?Caffeine 会帮助你解决这个问题。当然,你并不需要为你的电脑泡一杯咖啡。你只需要安装一个轻量级的指示器 —— Caffeine。只要当前你是全屏模式,它就会禁用你的屏幕保护程序、锁屏程序,让你的电脑不会因为没有在任务中而进入睡眠模式。
|
||||||
|
|
||||||
|
[点击下载][7]安装最新版本的 Caffeine。如果你想以[PPA的方式][8]安装,使用如下命令:
|
||||||
|
|
||||||
|
$ sudo add-apt-repository ppa:caffeine-developers/ppa
|
||||||
|
$ sudo apt-get update
|
||||||
|
$ sudo apt-get install caffeine
|
||||||
|
|
||||||
|
如果你的Ubuntu版本是14.10或者15.04(或者其它衍生版本),你还需要安装下面的依赖包:
|
||||||
|
|
||||||
|
$ sudo apt-get install libappindicator3-1 gir1.2-appindicator3-0.1
|
||||||
|
|
||||||
|
完成安装以后,将**Caffeine指示器**设置成开机自启动,这样可以使指示器显示在系统托盘里。你可以右键点击托盘图标打开应用的关联菜单,来开启或关闭Caffeine,
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/caffeine-indicator-640x480.jpg?92a7a3)
|
||||||
|
|
||||||
|
### Easystroke ###
|
||||||
|
|
||||||
|
Easystroke 是一个将[鼠标潜力][9]开发出来的应用。通过一系列的设置,用鼠标、触摸屏、手写笔的手势来完成敲击键盘、执行命令和滚动屏幕等通用操作。在 Easystroke 里能够设置的手势相当多,而且当你看到应用的界面时,你会发现应用的引导非常清晰。
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/easystroke-record-640x480.jpg?92a7a3)
|
||||||
|
|
||||||
|
选择一个你喜欢的鼠标键开始设置手势。如果你喜欢,你还可以设置辅助功能键。通过Perferences>Behavior>Gesture Button 来设置。现在到**Action**选项卡里面,把你最常用的动作记录成手势吧。
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/easytroke-actions-640x480.jpg?92a7a3)
|
||||||
|
|
||||||
|
在 Preferences 和 Advanced 选项卡中,你可以做一些其它的调整,比如将 EasyStroke 设置成自动启动,在系统托盘中显示图标,改变滚动速度。
|
||||||
|
|
||||||
|
### Guake ###
|
||||||
|
|
||||||
|
我把我最喜欢的应用放在最后。Guake 是根据第一人称射击视屏游戏 [Quake][10] 模仿而来的下拉式命令行终端。不管你是否在[学习命令行终端][11],或者是有一定的基础,Guake 都可以将终端变得更加方便。你可以一键将它呼出,也可以一键将它隐藏。
|
||||||
|
|
||||||
|
就像下面这张图,当打开时,Guake 的界面会覆盖在当前的屏幕上。你可以在终端中右键点击,调出 Preference 来改变 Guake 的界面,滚动方式,快捷键等等。
|
||||||
|
|
||||||
|
![](http://cdn.makeuseof.com/wp-content/uploads/2015/04/guake-terminal-640x480.jpg?92a7a3)
|
||||||
|
|
||||||
|
如果[你的桌面][12]是 KDE,你可以选择一个类似的工具——[Yakuake][13].
|
||||||
|
|
||||||
|
### 写下你最喜欢的Linux新发现!###
|
||||||
|
|
||||||
|
还有更多[超级实用的 Linux 应用][14]等待被发现。放心,我们将一直关注,并把它们带到你们的生活中。
|
||||||
|
|
||||||
|
哪一个应用是你最喜欢研究的呢?哪一个是你觉得必不可少的呢?在评论里告诉给我们吧。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.makeuseof.com/tag/new-linux-5-apps-didnt-know-missing/
|
||||||
|
|
||||||
|
作者:[Akshata][a]
|
||||||
|
译者:[sevenot](https://github.com/sevenot)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.makeuseof.com/tag/author/akshata/
|
||||||
|
[1]:http://synergy-project.org/
|
||||||
|
[2]:http://basket.kde.org/
|
||||||
|
[3]:http://www.makeuseof.com/tag/try-these-3-beautiful-note-taking-apps-that-work-offline/
|
||||||
|
[4]:http://getspringseed.com/
|
||||||
|
[5]:https://launchpad.net/caffeine
|
||||||
|
[6]:http://www.makeuseof.com/tag/popular-apps-movies-according-google/
|
||||||
|
[7]:http://ppa.launchpad.net/caffeine-developers/ppa/ubuntu/pool/main/c/caffeine/
|
||||||
|
[8]:http://www.makeuseof.com/tag/ubuntu-ppa-technology-explained/
|
||||||
|
[9]:http://www.makeuseof.com/tag/4-astounding-linux-mouse-hacks/
|
||||||
|
[10]:http://en.wikipedia.org/wiki/Quake_%28video_game%29
|
||||||
|
[11]:http://www.makeuseof.com/tag/4-ways-teach-terminal-commands-linux-si/
|
||||||
|
[12]:http://www.makeuseof.com/tag/10-top-linux-desktop-environments-available/
|
||||||
|
[13]:https://yakuake.kde.org/
|
||||||
|
[14]:http://www.makeuseof.com/tag/linux-treasures-x-sublime-native-linux-apps-will-make-want-switch/
|
@ -0,0 +1,115 @@
|
|||||||
|
Linux有问必答:nginx网络服务器上如何阻止特定用户代理(UA)
|
||||||
|
================================================================================
|
||||||
|
> **问题**: 我注意到有一些机器人经常访问我的nginx驱动的网站,并且进行一些攻击性的扫描,导致消耗掉了我的网络服务器的大量资源。我一直尝试着通过用户代理符串来阻挡这些机器人。我怎样才能在nginx网络服务器上阻挡掉特定的用户代理呢?
|
||||||
|
|
||||||
|
现代互联网滋生了大量各种各样的恶意机器人和网络爬虫,比如像恶意软件机器人、垃圾邮件程序或内容刮刀,这些恶意工具一直偷偷摸摸地扫描你的网站,干些诸如检测潜在网站漏洞、收获电子邮件地址,或者只是从你的网站偷取内容。大多数机器人能够通过它们的“用户代理”签名字符串来识别。
|
||||||
|
|
||||||
|
作为第一道防线,你可以尝试通过将这些机器人的用户代理字符串添加入robots.txt文件来阻止这些恶意软件机器人访问你的网站。但是,很不幸的是,该操作只针对那些“行为良好”的机器人,这些机器人被设计遵循robots.txt的规范。许多恶意软件机器人可以很容易地忽略掉robots.txt,然后随意扫描你的网站。
|
||||||
|
|
||||||
|
另一个用以阻挡特定机器人的途径,就是配置你的网络服务器,通过特定的用户代理字符串拒绝要求提供内容的请求。本文就是说明如何**在nginx网络服务器上阻挡特定的用户代理**。
|
||||||
|
|
||||||
|
### 在Nginx中将特定用户代理列入黑名单 ###
|
||||||
|
|
||||||
|
要配置用户代理阻挡列表,请打开你的网站的nginx配置文件,找到`server`定义部分。该文件可能会放在不同的地方,这取决于你的nginx配置或Linux版本(如,`/etc/nginx/nginx.conf`,`/etc/nginx/sites-enabled/<your-site>`,`/usr/local/nginx/conf/nginx.conf`,`/etc/nginx/conf.d/<your-site>`)。
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
server_name xmodulo.com;
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
|
||||||
|
....
|
||||||
|
}
|
||||||
|
|
||||||
|
在打开该配置文件并找到 `server` 部分后,添加以下 if 声明到该部分内的某个地方。
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
server_name xmodulo.com;
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
|
||||||
|
# 大小写敏感的匹配
|
||||||
|
if ($http_user_agent ~ (Antivirx|Arian) {
|
||||||
|
return 403;
|
||||||
|
}
|
||||||
|
|
||||||
|
#大小写无关的匹配
|
||||||
|
if ($http_user_agent ~* (netcrawl|npbot|malicious)) {
|
||||||
|
return 403;
|
||||||
|
}
|
||||||
|
|
||||||
|
....
|
||||||
|
}
|
||||||
|
|
||||||
|
如你所想,这些 if 声明使用正则表达式匹配了任意不良用户字符串,并向匹配的对象返回403 HTTP状态码。
|
||||||
|
`$http_user_agent`是HTTP请求中的一个包含有用户代理字符串的变量。‘~’操作符针对用户代理字符串进行大小写敏感匹配,而‘~*’操作符则进行大小写无关匹配。‘|’操作符是逻辑或,因此,你可以在 if 声明中放入众多的用户代理关键字,然后将它们全部阻挡掉。
|
||||||
|
|
||||||
|
在修改配置文件后,你必须重新加载nginx以激活阻挡:
|
||||||
|
|
||||||
|
$ sudo /path/to/nginx -s reload
|
||||||
|
|
||||||
|
你可以通过使用带有 “--user-agent” 选项的 wget 测试用户代理阻挡。
|
||||||
|
|
||||||
|
$ wget --user-agent "malicious bot" http://<nginx-ip-address>
|
||||||
|
|
||||||
|
![](https://farm6.staticflickr.com/5333/17434036358_ef139a6b59_b.jpg)
|
||||||
|
|
||||||
|
### 管理Nginx中的用户代理黑名单 ###
|
||||||
|
|
||||||
|
目前为止,我已经展示了在nginx中如何阻挡一些用户代理的HTTP请求。如果你有许多不同类型的网络爬虫机器人要阻挡,又该怎么办呢?
|
||||||
|
|
||||||
|
由于用户代理黑名单会增长得很大,所以将它们放在nginx的server部分不是个好点子。取而代之的是,你可以创建一个独立的文件,在该文件中列出所有被阻挡的用户代理。例如,让我们创建/etc/nginx/useragent.rules,并定义以下面的格式定义所有被阻挡的用户代理的图谱。
|
||||||
|
|
||||||
|
$ sudo vi /etc/nginx/useragent.rules
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
map $http_user_agent $badagent {
|
||||||
|
default 0;
|
||||||
|
~*malicious 1;
|
||||||
|
~*backdoor 1;
|
||||||
|
~*netcrawler 1;
|
||||||
|
~Antivirx 1;
|
||||||
|
~Arian 1;
|
||||||
|
~webbandit 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
与先前的配置类似,‘~*’将匹配以大小写不敏感的方式匹配关键字,而‘~’将使用大小写敏感的正则表达式匹配关键字。“default 0”行所表达的意思是,任何其它文件中未被列出的用户代理将被允许。
|
||||||
|
|
||||||
|
接下来,打开你的网站的nginx配置文件,找到里面包含 http 的部分,然后添加以下行到 http 部分某个位置。
|
||||||
|
|
||||||
|
http {
|
||||||
|
.....
|
||||||
|
include /etc/nginx/useragent.rules
|
||||||
|
}
|
||||||
|
|
||||||
|
注意,该 include 声明必须出现在 server 部分之前(这就是为什么我们将它添加到了 http 部分里)。
|
||||||
|
|
||||||
|
现在,打开nginx配置定义你的服务器的部分,添加以下 if 声明:
|
||||||
|
|
||||||
|
server {
|
||||||
|
....
|
||||||
|
|
||||||
|
if ($badagent) {
|
||||||
|
return 403;
|
||||||
|
}
|
||||||
|
|
||||||
|
....
|
||||||
|
}
|
||||||
|
|
||||||
|
最后,重新加载nginx。
|
||||||
|
|
||||||
|
$ sudo /path/to/nginx -s reload
|
||||||
|
|
||||||
|
现在,任何包含有`/etc/nginx/useragent.rules`中列出的关键字的用户代理将被nginx自动禁止。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://ask.xmodulo.com/block-specific-user-agents-nginx-web-server.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://ask.xmodulo.com/author/nanni
|
@ -0,0 +1,33 @@
|
|||||||
|
如何修复 “fatal error: security/pam_modules.h: No such file or directory”
|
||||||
|
================================================================================
|
||||||
|
> **问题**: 我尝试在 [某某 Linux 发行版] 上编译程序,但是出现下面的编译错误:
|
||||||
|
>
|
||||||
|
> "pam_otpw.c:27:34: fatal error: security/pam_modules.h: No such file or directory"
|
||||||
|
>
|
||||||
|
> 我怎样才能修复这个错误?
|
||||||
|
|
||||||
|
缺失的头文件 'security/pam_modules.h' 是 libpam 开发版的一部分,一个 PAM(Pluggable Authentication Modules:插入式验证模块)库。因此要修复这个错误,你需要安装 libpam 开发包,如下所示。
|
||||||
|
|
||||||
|
对于 Debian、 Ubuntu 或者 Linux Mint:
|
||||||
|
|
||||||
|
$ sudo apt-get install libpam0g-dev
|
||||||
|
|
||||||
|
对与 CentOS、 Fedora 或者 RHEL:
|
||||||
|
|
||||||
|
$ sudo yum install gcc pam-devel
|
||||||
|
|
||||||
|
现在验证缺失的头文件是否安装到了 /usr/include/security。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7751/16819069693_fa961f0d40_b.jpg)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://ask.xmodulo.com/fatal-error-security-pam-modules.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://ask.xmodulo.com/author/nanni
|
@ -0,0 +1,26 @@
|
|||||||
|
微软开源了WCF框架
|
||||||
|
================================================================================
|
||||||
|
微软于今日(2015/5/20)宣布了针对 .NET Core 重大开源:WCF(Windows Communication Foundation)。
|
||||||
|
|
||||||
|
如[MSDN][1]中的描述:“WCF是一个构建面向服务应用的框架。使用WCF,你可以从一个服务终端给另一个发送异步消息。服务终端可以是托管在IIS中连续可用的服务的一部分,也可以是托管在某个程序上的服务。服务终端可以是请求服务端数据的客户端。消息可以是一个字符或者XML,也可以是复杂的二进制流。”
|
||||||
|
|
||||||
|
它的[代码放在GitHub][2],“包含了Window桌面中完整WCF框架的一部分,它支持已经可用于构建Window Store上的WCF应用的库。这些主要是基于客户端,方便移动设备和中间层服务器使用WCF进行通信。”
|
||||||
|
|
||||||
|
更多的关于微软开源 WCF 的细节查看[dotNETFoundation.org blog][3]的公告。
|
||||||
|
|
||||||
|
WCF听上去有点像Linux中用于进程/服务之间的进程间通讯的D-BUS。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.phoronix.com/scan.php?page=news_item&px=Microsoft-Open-Source-WCF
|
||||||
|
|
||||||
|
作者:[Michael Larabel][a]
|
||||||
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.michaellarabel.com/
|
||||||
|
[1]:https://msdn.microsoft.com/en-us/library/ms731082%28v=vs.110%29.aspx
|
||||||
|
[2]:https://github.com/dotnet/wcf
|
||||||
|
[3]:http://www.dotnetfoundation.org/blog/wcf-is-open-source
|
@ -0,0 +1,33 @@
|
|||||||
|
Ubuntu 社区委员会要求 Kubuntu 项目领导人下台
|
||||||
|
================================================================================
|
||||||
|
> 而Jonathan Riddell拒绝从Kubuntu领导人位置退出
|
||||||
|
|
||||||
|
![](http://i1-news.softpedia-static.com/images/news2/Ubuntu-Community-Council-Asks-the-Kubuntu-Project-Leader-to-Step-Down-482384-2.jpg)
|
||||||
|
|
||||||
|
**这一切刚刚发生。一名Debian开发者以及Kubuntu委员会成员 Scott Kitterman 决定公开一些电子邮件,邮件披露了Ubuntu 社区委员会成员要求 Jonathan Riddell 从 Kubuntu 项目领导人位置退出的过程。**
|
||||||
|
|
||||||
|
Jonathan Riddell 是 KDE 以及 Kubuntu 的一名开发者,多年来也是 Ubuntu 社区的一名重要成员。从 Scott Kitterman [今天曝光的社区邮件往来][1]中来看,Jonathan Riddell 被指责对 Ubuntu 以及 Kubuntu 社区的一些成员咄咄逼人和挑衅。
|
||||||
|
|
||||||
|
长话短说,经过多轮邮件往来之后,Ubuntu 社区委员会的最终决定是让 Jonathan Riddell 退出他在 Ubuntu 以及Kubuntu 社区的领导人位置至少12个月,但仍可以像其他成员一样参与讨论。这个决定同时也得到了 Canonical 和Ubuntu 的创始人 Mark Shuttleworth 的支持。
|
||||||
|
|
||||||
|
“很遗憾写下了讨论这个我们觉得对 Ubuntu 社区有着消极影响的问题的邮件。长期以来,Jonathan Riddell 变得越来越难以交往。Jonathan 提出了有效的问题及关注,但当收到他不赞同的答案时,他的反应就不那么让人愉快了。”在 Ubuntu 社区委员会发出的第一封认为 Jonathan Riddell 行为“不友好”的邮件中这么写道。
|
||||||
|
|
||||||
|
### Jonathan Riddell拒绝从Kubuntu领导人位置退出 ###
|
||||||
|
|
||||||
|
从今天 Scott Kitterman 披露邮件往来,并决定在博客上写第二篇博文来看,表明了他想从他在 Ubuntu 和 Kubuntu 的位置退出,这表明 Jonathan Riddell 可能拒绝从 Kubuntu 领导人位置退出。
|
||||||
|
|
||||||
|
正如预料之中,Kubuntu 社区委员会的成员们支持 Jonathan Riddell,并且回击了 Ubuntu 社区委员会罢免 Kubuntu 项目领导人的决定。“我要感谢所有在 Kubuntu 委员会投票再次肯定我的 Kubuntu 成员。”,Jonathan Riddell 在[他的博客][2]上写道,“希望 Kubuntu 能够继续走下去,我也计划和我深爱的社区伙伴们一起为 15.10 发布而努力。”
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://news.softpedia.com/news/Ubuntu-Community-Council-Asks-the-Kubuntu-Project-Leader-to-Step-Down-482384.shtml
|
||||||
|
|
||||||
|
作者:[Marius Nestor][a]
|
||||||
|
译者:[alim0x](https://github.com/alim0x)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://news.softpedia.com/editors/browse/marius-nestor
|
||||||
|
[1]:https://skitterman.wordpress.com/
|
||||||
|
[2]:http://jriddell.org/
|
@ -1,12 +1,15 @@
|
|||||||
|
14 个 grep 命令的例子
|
||||||
|
===========
|
||||||
|
|
||||||
###概述:###
|
###概述:###
|
||||||
|
|
||||||
所有类linux系统都会提供一个名为**grep(global regular expression print)**的搜索工具。grep命令在基于模式对一个或多个文件内容进行搜索的情况下是非常有用的。一个模式可以是单个字符、多个字符、单个单词、或者是一个句子。
|
所有的类linux系统都会提供一个名为**grep(global regular expression print,全局正则表达式输出)**的搜索工具。grep命令在对一个或多个文件的内容进行基于模式的搜索的情况下是非常有用的。模式可以是单个字符、多个字符、单个单词、或者是一个句子。
|
||||||
|
|
||||||
当命令匹配到执行命令时指定的模式时,grep会将包含模式的一行输出,但是并不对原文件内容进行修改。
|
当命令匹配到执行命令时指定的模式时,grep会将包含模式的一行输出,但是并不对原文件内容进行修改。
|
||||||
|
|
||||||
在本文中,我们将会讨论到14个grep命令的例子。
|
在本文中,我们将会讨论到14个grep命令的例子。
|
||||||
|
|
||||||
###1 在文件中查找模式(单词)###
|
###例1 在文件中查找模式(单词)###
|
||||||
|
|
||||||
在/etc/passwd文件中查找单词“linuxtechi”
|
在/etc/passwd文件中查找单词“linuxtechi”
|
||||||
|
|
||||||
@ -14,7 +17,7 @@
|
|||||||
linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
###2 在多个文件中查找模式。###
|
###例2 在多个文件中查找模式。###
|
||||||
|
|
||||||
root@Linux-world:~# grep linuxtechi /etc/passwd /etc/shadow /etc/gshadow
|
root@Linux-world:~# grep linuxtechi /etc/passwd /etc/shadow /etc/gshadow
|
||||||
/etc/passwd:linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
/etc/passwd:linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
||||||
@ -28,14 +31,14 @@
|
|||||||
/etc/gshadow:sambashare:!::linuxtechi
|
/etc/gshadow:sambashare:!::linuxtechi
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
###3 使用-l参数列出包含指定模式的文件的文件名。###
|
###例3 使用-l参数列出包含指定模式的文件的文件名。###
|
||||||
|
|
||||||
root@Linux-world:~# grep -l linuxtechi /etc/passwd /etc/shadow /etc/fstab /etc/mtab
|
root@Linux-world:~# grep -l linuxtechi /etc/passwd /etc/shadow /etc/fstab /etc/mtab
|
||||||
/etc/passwd
|
/etc/passwd
|
||||||
/etc/shadow
|
/etc/shadow
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
###4 使用-n参数,在文件中查找指定模式及其相关的行号###
|
###例4 使用-n参数,在文件中查找指定模式并显示匹配行的行号###
|
||||||
|
|
||||||
root@Linux-world:~# grep -n linuxtechi /etc/passwd
|
root@Linux-world:~# grep -n linuxtechi /etc/passwd
|
||||||
39:linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
39:linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
||||||
@ -45,7 +48,7 @@ root@Linux-world:~# grep -n root /etc/passwd /etc/shadow
|
|||||||
|
|
||||||
![](http://www.linuxtechi.com/wp-content/uploads/2015/05/grep-n-root.jpg)
|
![](http://www.linuxtechi.com/wp-content/uploads/2015/05/grep-n-root.jpg)
|
||||||
|
|
||||||
###5 使用-v参数输出不包含指定模式的行###
|
###例5 使用-v参数输出不包含指定模式的行###
|
||||||
|
|
||||||
输出/etc/passwd文件中所有不含单词“linuxtechi”的行
|
输出/etc/passwd文件中所有不含单词“linuxtechi”的行
|
||||||
|
|
||||||
@ -53,15 +56,15 @@ root@Linux-world:~# grep -n root /etc/passwd /etc/shadow
|
|||||||
|
|
||||||
![](http://www.linuxtechi.com/wp-content/uploads/2015/05/grep-v-option.jpg)
|
![](http://www.linuxtechi.com/wp-content/uploads/2015/05/grep-v-option.jpg)
|
||||||
|
|
||||||
###6 使用^符号输出所有以某指定模式开头的行###
|
###例6 使用 ^ 符号输出所有以某指定模式开头的行###
|
||||||
|
|
||||||
Bash脚本将^符号当作特殊字符处理,用于指定一行或者一个单词的开始。例如输出/etc/passes文件中所有以“root”开头的行
|
Bash脚本将 ^ 符号视作特殊字符,用于指定一行或者一个单词的开始。例如输出/etc/passes文件中所有以“root”开头的行
|
||||||
|
|
||||||
root@Linux-world:~# grep ^root /etc/passwd
|
root@Linux-world:~# grep ^root /etc/passwd
|
||||||
root:x:0:0:root:/root:/bin/bash
|
root:x:0:0:root:/root:/bin/bash
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
###7 使用 $ 符号输出所有以指定模式结尾的行。###
|
###例7 使用 $ 符号输出所有以指定模式结尾的行。###
|
||||||
|
|
||||||
输出/etc/passwd文件中所有以“bash”结尾的行。
|
输出/etc/passwd文件中所有以“bash”结尾的行。
|
||||||
|
|
||||||
@ -70,10 +73,9 @@ Bash脚本将^符号当作特殊字符处理,用于指定一行或者一个单
|
|||||||
linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
Bash脚本将美元($)符号当作特殊字符,用于指定一行或者一个单词的结尾。
|
Bash脚本将美元($)符号视作特殊字符,用于指定一行或者一个单词的结尾。
|
||||||
|
|
||||||
###8 使用 -r 参数递归的查找特定模式###
|
|
||||||
|
|
||||||
|
###例8 使用 -r 参数递归地查找特定模式###
|
||||||
|
|
||||||
root@Linux-world:~# grep -r linuxtechi /etc/
|
root@Linux-world:~# grep -r linuxtechi /etc/
|
||||||
/etc/subuid:linuxtechi:100000:65536
|
/etc/subuid:linuxtechi:100000:65536
|
||||||
@ -91,14 +93,14 @@ Bash脚本将美元($)符号当作特殊字符,用于指定一行或者一个
|
|||||||
|
|
||||||
上面的命令将会递归的在/etc目录中查找“linuxtechi”单词
|
上面的命令将会递归的在/etc目录中查找“linuxtechi”单词
|
||||||
|
|
||||||
###9 使用grep查找文件中所有的空行
|
###例9 使用 grep 查找文件中所有的空行
|
||||||
|
|
||||||
root@Linux-world:~# grep ^$ /etc/shadow
|
root@Linux-world:~# grep ^$ /etc/shadow
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
由于/etc/shadow文件中没有空行,所以没有任何输出
|
由于/etc/shadow文件中没有空行,所以没有任何输出
|
||||||
|
|
||||||
###10 使用“grep -i”参数查找模式###
|
###例10 使用 -i 参数查找模式###
|
||||||
|
|
||||||
grep命令的-i参数在查找时忽略字符的大小写。
|
grep命令的-i参数在查找时忽略字符的大小写。
|
||||||
|
|
||||||
@ -108,7 +110,7 @@ grep命令的-i参数在查找时忽略字符的大小写。
|
|||||||
linuxtechi:x:1001:1001::/home/linuxtechi:/bin/bash
|
linuxtechi:x:1001:1001::/home/linuxtechi:/bin/bash
|
||||||
nextstep4it@localhost:~$
|
nextstep4it@localhost:~$
|
||||||
|
|
||||||
###11 使用-e参数查找多个模式###
|
###例11 使用 -e 参数查找多个模式###
|
||||||
|
|
||||||
例如,我想在一条grep命令中查找‘linuxtechi’和‘root’单词,使用-e参数,我们可以查找多个模式。
|
例如,我想在一条grep命令中查找‘linuxtechi’和‘root’单词,使用-e参数,我们可以查找多个模式。
|
||||||
|
|
||||||
@ -117,7 +119,7 @@ grep命令的-i参数在查找时忽略字符的大小写。
|
|||||||
linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
linuxtechi:x:1000:1000:linuxtechi,,,:/home/linuxtechi:/bin/bash
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
###12 使用“grep -f”从一个文件中获取待查找的模式###
|
###例12 使用 -f 用文件指定待查找的模式###
|
||||||
|
|
||||||
首先,在当前目录中创建一个搜索模式文件“grep_pattern”,我想文件中输入的如下内容。
|
首先,在当前目录中创建一个搜索模式文件“grep_pattern”,我想文件中输入的如下内容。
|
||||||
|
|
||||||
@ -133,7 +135,7 @@ grep命令的-i参数在查找时忽略字符的大小写。
|
|||||||
|
|
||||||
![](http://www.linuxtechi.com/wp-content/uploads/2015/05/grep-f-option.jpg)
|
![](http://www.linuxtechi.com/wp-content/uploads/2015/05/grep-f-option.jpg)
|
||||||
|
|
||||||
###13 使用-c参数计算模式匹配的数量###
|
###例13 使用 -c 参数计算模式匹配到的数量###
|
||||||
|
|
||||||
继续上面例子,我们在grep命令中使用-c命令计算匹配指定模式的数量
|
继续上面例子,我们在grep命令中使用-c命令计算匹配指定模式的数量
|
||||||
|
|
||||||
@ -141,7 +143,7 @@ grep命令的-i参数在查找时忽略字符的大小写。
|
|||||||
22
|
22
|
||||||
root@Linux-world:~#
|
root@Linux-world:~#
|
||||||
|
|
||||||
###14 输出匹配指定模式行的前或者后面N行###
|
###例14 输出匹配指定模式行的前或者后面N行###
|
||||||
|
|
||||||
a)使用-B参数输出匹配行的前4行
|
a)使用-B参数输出匹配行的前4行
|
||||||
|
|
||||||
@ -167,7 +169,7 @@ via: http://www.linuxtechi.com/linux-grep-command-with-14-different-examples/
|
|||||||
|
|
||||||
作者:[Pradeep Kumar][a]
|
作者:[Pradeep Kumar][a]
|
||||||
译者:[cvsher](https://github.com/cvsher)
|
译者:[cvsher](https://github.com/cvsher)
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
@ -0,0 +1,131 @@
|
|||||||
|
如何通过反向 SSH 隧道访问 NAT 后面的 Linux 服务器
|
||||||
|
================================================================================
|
||||||
|
你在家里运行着一台 Linux 服务器,它放在一个 NAT 路由器或者限制性防火墙后面。现在你想在外出时用 SSH 登录到这台服务器。你如何才能做到呢?SSH 端口转发当然是一种选择。但是,如果你需要处理多级嵌套的 NAT 环境,端口转发可能会变得非常棘手。另外,在多种 ISP 特定条件下可能会受到干扰,例如阻塞转发端口的限制性 ISP 防火墙、或者在用户间共享 IPv4 地址的运营商级 NAT。
|
||||||
|
|
||||||
|
### 什么是反向 SSH 隧道? ###
|
||||||
|
|
||||||
|
SSH 端口转发的一种替代方案是 **反向 SSH 隧道**。反向 SSH 隧道的概念非常简单。使用这种方案,在你的受限的家庭网络之外你需要另一台主机(所谓的“中继主机”),你能从当前所在地通过 SSH 登录到它。你可以用有公网 IP 地址的 [VPS 实例][1] 配置一个中继主机。然后要做的就是从你的家庭网络服务器中建立一个到公网中继主机的永久 SSH 隧道。有了这个隧道,你就可以从中继主机中连接“回”家庭服务器(这就是为什么称之为 “反向” 隧道)。不管你在哪里、你的家庭网络中的 NAT 或 防火墙限制多么严格,只要你可以访问中继主机,你就可以连接到家庭服务器。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7742/17162647378_c7d9f10de8_b.jpg)
|
||||||
|
|
||||||
|
### 在 Linux 上设置反向 SSH 隧道 ###
|
||||||
|
|
||||||
|
让我们来看看怎样创建和使用反向 SSH 隧道。我们做如下假设:我们会设置一个从家庭服务器(homeserver)到中继服务器(relayserver)的反向 SSH 隧道,然后我们可以通过中继服务器从客户端计算机(clientcomputer) SSH 登录到家庭服务器。本例中的**中继服务器** 的公网 IP 地址是 1.1.1.1。
|
||||||
|
|
||||||
|
在家庭服务器上,按照以下方式打开一个到中继服务器的 SSH 连接。
|
||||||
|
|
||||||
|
homeserver~$ ssh -fN -R 10022:localhost:22 relayserver_user@1.1.1.1
|
||||||
|
|
||||||
|
这里端口 10022 是任何你可以使用的端口数字。只需要确保中继服务器上不会有其它程序使用这个端口。
|
||||||
|
|
||||||
|
“-R 10022:localhost:22” 选项定义了一个反向隧道。它转发中继服务器 10022 端口的流量到家庭服务器的 22 号端口。
|
||||||
|
|
||||||
|
用 “-fN” 选项,当你成功通过 SSH 服务器验证时 SSH 会进入后台运行。当你不想在远程 SSH 服务器执行任何命令,就像我们的例子中只想转发端口的时候非常有用。
|
||||||
|
|
||||||
|
运行上面的命令之后,你就会回到家庭主机的命令行提示框中。
|
||||||
|
|
||||||
|
登录到中继服务器,确认其 127.0.0.1:10022 绑定到了 sshd。如果是的话就表示已经正确设置了反向隧道。
|
||||||
|
|
||||||
|
relayserver~$ sudo netstat -nap | grep 10022
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
tcp 0 0 127.0.0.1:10022 0.0.0.0:* LISTEN 8493/sshd
|
||||||
|
|
||||||
|
现在就可以从任何其它计算机(客户端计算机)登录到中继服务器,然后按照下面的方法访问家庭服务器。
|
||||||
|
|
||||||
|
relayserver~$ ssh -p 10022 homeserver_user@localhost
|
||||||
|
|
||||||
|
需要注意的一点是你在上面为localhost输入的 SSH 登录/密码应该是家庭服务器的,而不是中继服务器的,因为你是通过隧道的本地端点登录到家庭服务器,因此不要错误输入中继服务器的登录/密码。成功登录后,你就在家庭服务器上了。
|
||||||
|
|
||||||
|
### 通过反向 SSH 隧道直接连接到网络地址变换后的服务器 ###
|
||||||
|
|
||||||
|
上面的方法允许你访问 NAT 后面的 **家庭服务器**,但你需要登录两次:首先登录到 **中继服务器**,然后再登录到**家庭服务器**。这是因为中继服务器上 SSH 隧道的端点绑定到了回环地址(127.0.0.1)。
|
||||||
|
|
||||||
|
事实上,有一种方法可以只需要登录到中继服务器就能直接访问NAT之后的家庭服务器。要做到这点,你需要让中继服务器上的 sshd 不仅转发回环地址上的端口,还要转发外部主机的端口。这通过指定中继服务器上运行的 sshd 的 **GatewayPorts** 实现。
|
||||||
|
|
||||||
|
打开**中继服务器**的 /etc/ssh/sshd_conf 并添加下面的行。
|
||||||
|
|
||||||
|
relayserver~$ vi /etc/ssh/sshd_conf
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
GatewayPorts clientspecified
|
||||||
|
|
||||||
|
重启 sshd。
|
||||||
|
|
||||||
|
基于 Debian 的系统:
|
||||||
|
|
||||||
|
relayserver~$ sudo /etc/init.d/ssh restart
|
||||||
|
|
||||||
|
基于红帽的系统:
|
||||||
|
|
||||||
|
relayserver~$ sudo systemctl restart sshd
|
||||||
|
|
||||||
|
现在在家庭服务器中按照下面方式初始化一个反向 SSH 隧道。
|
||||||
|
|
||||||
|
homeserver~$ ssh -fN -R 1.1.1.1:10022:localhost:22 relayserver_user@1.1.1.1
|
||||||
|
|
||||||
|
登录到中继服务器然后用 netstat 命令确认成功建立的一个反向 SSH 隧道。
|
||||||
|
|
||||||
|
relayserver~$ sudo netstat -nap | grep 10022
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
tcp 0 0 1.1.1.1:10022 0.0.0.0:* LISTEN 1538/sshd: dev
|
||||||
|
|
||||||
|
不像之前的情况,现在隧道的端点是 1.1.1.1:10022(中继服务器的公网 IP 地址),而不是 127.0.0.1:10022。这就意味着从外部主机可以访问隧道的另一端。
|
||||||
|
|
||||||
|
现在在任何其它计算机(客户端计算机),输入以下命令访问网络地址变换之后的家庭服务器。
|
||||||
|
|
||||||
|
clientcomputer~$ ssh -p 10022 homeserver_user@1.1.1.1
|
||||||
|
|
||||||
|
在上面的命令中,1.1.1.1 是中继服务器的公共 IP 地址,homeserver_user必须是家庭服务器上的用户账户。这是因为你真正登录到的主机是家庭服务器,而不是中继服务器。后者只是中继你的 SSH 流量到家庭服务器。
|
||||||
|
|
||||||
|
### 在 Linux 上设置一个永久反向 SSH 隧道 ###
|
||||||
|
|
||||||
|
现在你已经明白了怎样创建一个反向 SSH 隧道,然后把隧道设置为 “永久”,这样隧道启动后就会一直运行(不管临时的网络拥塞、SSH 超时、中继主机重启,等等)。毕竟,如果隧道不是一直有效,你就不能可靠的登录到你的家庭服务器。
|
||||||
|
|
||||||
|
对于永久隧道,我打算使用一个叫 autossh 的工具。正如名字暗示的,这个程序可以让你的 SSH 会话无论因为什么原因中断都会自动重连。因此对于保持一个反向 SSH 隧道非常有用。
|
||||||
|
|
||||||
|
第一步,我们要设置从家庭服务器到中继服务器的[无密码 SSH 登录][2]。这样的话,autossh 可以不需要用户干预就能重启一个损坏的反向 SSH 隧道。
|
||||||
|
|
||||||
|
下一步,在建立隧道的家庭服务器上[安装 autossh][3]。
|
||||||
|
|
||||||
|
在家庭服务器上,用下面的参数运行 autossh 来创建一个连接到中继服务器的永久 SSH 隧道。
|
||||||
|
|
||||||
|
homeserver~$ autossh -M 10900 -fN -o "PubkeyAuthentication=yes" -o "StrictHostKeyChecking=false" -o "PasswordAuthentication=no" -o "ServerAliveInterval 60" -o "ServerAliveCountMax 3" -R 1.1.1.1:10022:localhost:22 relayserver_user@1.1.1.1
|
||||||
|
|
||||||
|
“-M 10900” 选项指定中继服务器上的监视端口,用于交换监视 SSH 会话的测试数据。中继服务器上的其它程序不能使用这个端口。
|
||||||
|
|
||||||
|
“-fN” 选项传递给 ssh 命令,让 SSH 隧道在后台运行。
|
||||||
|
|
||||||
|
“-o XXXX” 选项让 ssh:
|
||||||
|
|
||||||
|
- 使用密钥验证,而不是密码验证。
|
||||||
|
- 自动接受(未知)SSH 主机密钥。
|
||||||
|
- 每 60 秒交换 keep-alive 消息。
|
||||||
|
- 没有收到任何响应时最多发送 3 条 keep-alive 消息。
|
||||||
|
|
||||||
|
其余 SSH 隧道相关的选项和之前介绍的一样。
|
||||||
|
|
||||||
|
如果你想系统启动时自动运行 SSH 隧道,你可以将上面的 autossh 命令添加到 /etc/rc.local。
|
||||||
|
|
||||||
|
### 总结 ###
|
||||||
|
|
||||||
|
在这篇博文中,我介绍了你如何能从外部通过反向 SSH 隧道访问限制性防火墙或 NAT 网关之后的 Linux 服务器。这里我介绍了家庭网络中的一个使用事例,但在企业网络中使用时你尤其要小心。这样的一个隧道可能被视为违反公司政策,因为它绕过了企业的防火墙并把企业网络暴露给外部攻击。这很可能被误用或者滥用。因此在使用之前一定要记住它的作用。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/access-linux-server-behind-nat-reverse-ssh-tunnel.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/nanni
|
||||||
|
[1]:http://xmodulo.com/go/digitalocean
|
||||||
|
[2]:https://linux.cn/article-5444-1.html
|
||||||
|
[3]:https://linux.cn/article-5459-1.html
|
183
published/20150522 Analyzing Linux Logs.md
Normal file
183
published/20150522 Analyzing Linux Logs.md
Normal file
@ -0,0 +1,183 @@
|
|||||||
|
如何分析 Linux 日志
|
||||||
|
==============================================================================
|
||||||
|
![](http://www.loggly.com/ultimate-guide/wp-content/uploads/2015/05/Linux-Copy@2x1.png)
|
||||||
|
|
||||||
|
日志中有大量的信息需要你处理,尽管有时候想要提取并非想象中的容易。在这篇文章中我们会介绍一些你现在就能做的基本日志分析例子(只需要搜索即可)。我们还将涉及一些更高级的分析,但这些需要你前期努力做出适当的设置,后期就能节省很多时间。对数据进行高级分析的例子包括生成汇总计数、对有效值进行过滤,等等。
|
||||||
|
|
||||||
|
我们首先会向你展示如何在命令行中使用多个不同的工具,然后展示了一个日志管理工具如何能自动完成大部分繁重工作从而使得日志分析变得简单。
|
||||||
|
|
||||||
|
### 用 Grep 搜索 ###
|
||||||
|
|
||||||
|
搜索文本是查找信息最基本的方式。搜索文本最常用的工具是 [grep][1]。这个命令行工具在大部分 Linux 发行版中都有,它允许你用正则表达式搜索日志。正则表达式是一种用特殊的语言写的、能识别匹配文本的模式。最简单的模式就是用引号把你想要查找的字符串括起来。
|
||||||
|
|
||||||
|
#### 正则表达式 ####
|
||||||
|
|
||||||
|
这是一个在 Ubuntu 系统的认证日志中查找 “user hoover” 的例子:
|
||||||
|
|
||||||
|
$ grep "user hoover" /var/log/auth.log
|
||||||
|
Accepted password for hoover from 10.0.2.2 port 4792 ssh2
|
||||||
|
pam_unix(sshd:session): session opened for user hoover by (uid=0)
|
||||||
|
pam_unix(sshd:session): session closed for user hoover
|
||||||
|
|
||||||
|
构建精确的正则表达式可能很难。例如,如果我们想要搜索一个类似端口 “4792” 的数字,它可能也会匹配时间戳、URL 以及其它不需要的数据。Ubuntu 中下面的例子,它匹配了一个我们不想要的 Apache 日志。
|
||||||
|
|
||||||
|
$ grep "4792" /var/log/auth.log
|
||||||
|
Accepted password for hoover from 10.0.2.2 port 4792 ssh2
|
||||||
|
74.91.21.46 - - [31/Mar/2015:19:44:32 +0000] "GET /scripts/samples/search?q=4972 HTTP/1.0" 404 545 "-" "-”
|
||||||
|
|
||||||
|
#### 环绕搜索 ####
|
||||||
|
|
||||||
|
另一个有用的小技巧是你可以用 grep 做环绕搜索。这会向你展示一个匹配前面或后面几行是什么。它能帮助你调试导致错误或问题的东西。`B` 选项展示前面几行,`A` 选项展示后面几行。举个例子,我们知道当一个人以管理员员身份登录失败时,同时他们的 IP 也没有反向解析,也就意味着他们可能没有有效的域名。这非常可疑!
|
||||||
|
|
||||||
|
$ grep -B 3 -A 2 'Invalid user' /var/log/auth.log
|
||||||
|
Apr 28 17:06:20 ip-172-31-11-241 sshd[12545]: reverse mapping checking getaddrinfo for 216-19-2-8.commspeed.net [216.19.2.8] failed - POSSIBLE BREAK-IN ATTEMPT!
|
||||||
|
Apr 28 17:06:20 ip-172-31-11-241 sshd[12545]: Received disconnect from 216.19.2.8: 11: Bye Bye [preauth]
|
||||||
|
Apr 28 17:06:20 ip-172-31-11-241 sshd[12547]: Invalid user admin from 216.19.2.8
|
||||||
|
Apr 28 17:06:20 ip-172-31-11-241 sshd[12547]: input_userauth_request: invalid user admin [preauth]
|
||||||
|
Apr 28 17:06:20 ip-172-31-11-241 sshd[12547]: Received disconnect from 216.19.2.8: 11: Bye Bye [preauth]
|
||||||
|
|
||||||
|
#### Tail ####
|
||||||
|
|
||||||
|
你也可以把 grep 和 [tail][2] 结合使用来获取一个文件的最后几行,或者跟踪日志并实时打印。这在你做交互式更改的时候非常有用,例如启动服务器或者测试代码更改。
|
||||||
|
|
||||||
|
$ tail -f /var/log/auth.log | grep 'Invalid user'
|
||||||
|
Apr 30 19:49:48 ip-172-31-11-241 sshd[6512]: Invalid user ubnt from 219.140.64.136
|
||||||
|
Apr 30 19:49:49 ip-172-31-11-241 sshd[6514]: Invalid user admin from 219.140.64.136
|
||||||
|
|
||||||
|
关于 grep 和正则表达式的详细介绍并不在本指南的范围,但 [Ryan’s Tutorials][3] 有更深入的介绍。
|
||||||
|
|
||||||
|
日志管理系统有更高的性能和更强大的搜索能力。它们通常会索引数据并进行并行查询,因此你可以很快的在几秒内就能搜索 GB 或 TB 的日志。相比之下,grep 就需要几分钟,在极端情况下可能甚至几小时。日志管理系统也使用类似 [Lucene][4] 的查询语言,它提供更简单的语法来检索数字、域以及其它。
|
||||||
|
|
||||||
|
### 用 Cut、 AWK、 和 Grok 解析 ###
|
||||||
|
|
||||||
|
#### 命令行工具 ####
|
||||||
|
|
||||||
|
Linux 提供了多个命令行工具用于文本解析和分析。当你想要快速解析少量数据时非常有用,但处理大量数据时可能需要很长时间。
|
||||||
|
|
||||||
|
#### Cut ####
|
||||||
|
|
||||||
|
[cut][5] 命令允许你从有分隔符的日志解析字段。分隔符是指能分开字段或键值对的等号或逗号等。
|
||||||
|
|
||||||
|
假设我们想从下面的日志中解析出用户:
|
||||||
|
|
||||||
|
pam_unix(su:auth): authentication failure; logname=hoover uid=1000 euid=0 tty=/dev/pts/0 ruser=hoover rhost= user=root
|
||||||
|
|
||||||
|
我们可以像下面这样用 cut 命令获取用等号分割后的第八个字段的文本。这是一个 Ubuntu 系统上的例子:
|
||||||
|
|
||||||
|
$ grep "authentication failure" /var/log/auth.log | cut -d '=' -f 8
|
||||||
|
root
|
||||||
|
hoover
|
||||||
|
root
|
||||||
|
nagios
|
||||||
|
nagios
|
||||||
|
|
||||||
|
#### AWK ####
|
||||||
|
|
||||||
|
另外,你也可以使用 [awk][6],它能提供更强大的解析字段功能。它提供了一个脚本语言,你可以过滤出几乎任何不相干的东西。
|
||||||
|
|
||||||
|
例如,假设在 Ubuntu 系统中我们有下面的一行日志,我们想要提取登录失败的用户名称:
|
||||||
|
|
||||||
|
Mar 24 08:28:18 ip-172-31-11-241 sshd[32701]: input_userauth_request: invalid user guest [preauth]
|
||||||
|
|
||||||
|
你可以像下面这样使用 awk 命令。首先,用一个正则表达式 /sshd.*invalid user/ 来匹配 sshd invalid user 行。然后用 { print $9 } 根据默认的分隔符空格打印第九个字段。这样就输出了用户名。
|
||||||
|
|
||||||
|
$ awk '/sshd.*invalid user/ { print $9 }' /var/log/auth.log
|
||||||
|
guest
|
||||||
|
admin
|
||||||
|
info
|
||||||
|
test
|
||||||
|
ubnt
|
||||||
|
|
||||||
|
你可以在 [Awk 用户指南][7] 中阅读更多关于如何使用正则表达式和输出字段的信息。
|
||||||
|
|
||||||
|
#### 日志管理系统 ####
|
||||||
|
|
||||||
|
日志管理系统使得解析变得更加简单,使用户能快速的分析很多的日志文件。他们能自动解析标准的日志格式,比如常见的 Linux 日志和 Web 服务器日志。这能节省很多时间,因为当处理系统问题的时候你不需要考虑自己写解析逻辑。
|
||||||
|
|
||||||
|
下面是一个 sshd 日志消息的例子,解析出了每个 remoteHost 和 user。这是 Loggly 中的一张截图,它是一个基于云的日志管理服务。
|
||||||
|
|
||||||
|
![](http://www.loggly.com/ultimate-guide/wp-content/uploads/2015/05/Screen-Shot-2015-03-12-at-11.25.09-AM.png)
|
||||||
|
|
||||||
|
你也可以对非标准格式自定义解析。一个常用的工具是 [Grok][8],它用一个常见正则表达式库,可以解析原始文本为结构化 JSON。下面是一个 Grok 在 Logstash 中解析内核日志文件的事例配置:
|
||||||
|
|
||||||
|
filter{
|
||||||
|
grok {
|
||||||
|
match => {"message" => "%{CISCOTIMESTAMP:timestamp} %{HOST:host} %{WORD:program}%{NOTSPACE} %{NOTSPACE}%{NUMBER:duration}%{NOTSPACE} %{GREEDYDATA:kernel_logs}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
下图是 Grok 解析后输出的结果:
|
||||||
|
|
||||||
|
![](http://www.loggly.com/ultimate-guide/wp-content/uploads/2015/05/Screen-Shot-2015-03-12-at-11.30.37-AM.png)
|
||||||
|
|
||||||
|
### 用 Rsyslog 和 AWK 过滤 ###
|
||||||
|
|
||||||
|
过滤使得你能检索一个特定的字段值而不是进行全文检索。这使你的日志分析更加准确,因为它会忽略来自其它部分日志信息不需要的匹配。为了对一个字段值进行搜索,你首先需要解析日志或者至少有对事件结构进行检索的方式。
|
||||||
|
|
||||||
|
#### 如何对应用进行过滤 ####
|
||||||
|
|
||||||
|
通常,你可能只想看一个应用的日志。如果你的应用把记录都保存到一个文件中就会很容易。如果你需要在一个聚集或集中式日志中过滤一个应用就会比较复杂。下面有几种方法来实现:
|
||||||
|
|
||||||
|
1. 用 rsyslog 守护进程解析和过滤日志。下面的例子将 sshd 应用的日志写入一个名为 sshd-message 的文件,然后丢弃事件以便它不会在其它地方重复出现。你可以将它添加到你的 rsyslog.conf 文件中测试这个例子。
|
||||||
|
|
||||||
|
:programname, isequal, “sshd” /var/log/sshd-messages
|
||||||
|
&~
|
||||||
|
|
||||||
|
2. 用类似 awk 的命令行工具提取特定字段的值,例如 sshd 用户名。下面是 Ubuntu 系统中的一个例子。
|
||||||
|
|
||||||
|
$ awk '/sshd.*invalid user/ { print $9 }' /var/log/auth.log
|
||||||
|
guest
|
||||||
|
admin
|
||||||
|
info
|
||||||
|
test
|
||||||
|
ubnt
|
||||||
|
|
||||||
|
3. 用日志管理系统自动解析日志,然后在需要的应用名称上点击过滤。下面是在 Loggly 日志管理服务中提取 syslog 域的截图。我们对应用名称 “sshd” 进行过滤,如维恩图图标所示。
|
||||||
|
|
||||||
|
![](http://www.loggly.com/ultimate-guide/wp-content/uploads/2015/05/Screen-Shot-2015-03-12-at-11.05.02-AM.png)
|
||||||
|
|
||||||
|
#### 如何过滤错误 ####
|
||||||
|
|
||||||
|
一个人最希望看到日志中的错误。不幸的是,默认的 syslog 配置不直接输出错误的严重性,也就使得难以过滤它们。
|
||||||
|
|
||||||
|
这里有两个解决该问题的方法。首先,你可以修改你的 rsyslog 配置,在日志文件中输出错误的严重性,使得便于查看和检索。在你的 rsyslog 配置中你可以用 pri-text 添加一个 [模板][9],像下面这样:
|
||||||
|
|
||||||
|
"<%pri-text%> : %timegenerated%,%HOSTNAME%,%syslogtag%,%msg%n"
|
||||||
|
|
||||||
|
这个例子会按照下面的格式输出。你可以看到该信息中指示错误的 err。
|
||||||
|
|
||||||
|
<authpriv.err> : Mar 11 18:18:00,hoover-VirtualBox,su[5026]:, pam_authenticate: Authentication failure
|
||||||
|
|
||||||
|
你可以用 awk 或者 grep 检索错误信息。在 Ubuntu 中,对这个例子,我们可以用一些语法特征,例如 . 和 >,它们只会匹配这个域。
|
||||||
|
|
||||||
|
$ grep '.err>' /var/log/auth.log
|
||||||
|
<authpriv.err> : Mar 11 18:18:00,hoover-VirtualBox,su[5026]:, pam_authenticate: Authentication failure
|
||||||
|
|
||||||
|
你的第二个选择是使用日志管理系统。好的日志管理系统能自动解析 syslog 消息并抽取错误域。它们也允许你用简单的点击过滤日志消息中的特定错误。
|
||||||
|
|
||||||
|
下面是 Loggly 中一个截图,显示了高亮错误严重性的 syslog 域,表示我们正在过滤错误:
|
||||||
|
|
||||||
|
![](http://www.loggly.com/ultimate-guide/wp-content/uploads/2015/05/Screen-Shot-2015-03-12-at-11.00.36-AM.png)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.loggly.com/ultimate-guide/logging/analyzing-linux-logs/
|
||||||
|
|
||||||
|
作者:[Jason Skowronski][a],[Amy Echeverri][b],[ Sadequl Hussain][c]
|
||||||
|
译者:[ictlyh](https://github.com/ictlyh)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:https://www.linkedin.com/in/jasonskowronski
|
||||||
|
[b]:https://www.linkedin.com/in/amyecheverri
|
||||||
|
[c]:https://www.linkedin.com/pub/sadequl-hussain/14/711/1a7
|
||||||
|
[1]:http://linux.die.net/man/1/grep
|
||||||
|
[2]:http://linux.die.net/man/1/tail
|
||||||
|
[3]:http://ryanstutorials.net/linuxtutorial/grep.php
|
||||||
|
[4]:https://lucene.apache.org/core/2_9_4/queryparsersyntax.html
|
||||||
|
[5]:http://linux.die.net/man/1/cut
|
||||||
|
[6]:http://linux.die.net/man/1/awk
|
||||||
|
[7]:http://www.delorie.com/gnu/docs/gawk/gawk_26.html#IDX155
|
||||||
|
[8]:http://logstash.net/docs/1.4.2/filters/grok
|
||||||
|
[9]:http://www.rsyslog.com/doc/v8-stable/configuration/templates.html
|
@ -0,0 +1,222 @@
|
|||||||
|
适合于远程编辑以及更多环境的简洁文本编辑器
|
||||||
|
================================================================================
|
||||||
|
文本编辑器是用来编辑纯文本的软件。这种软件有许多用处,包括修改配置文件,编写程序源代码,记下一些想法或者甚至写一份购物列表。由于这种编辑器能都用于许多不同的方面,因此值得花些时间找一个最适合您喜好的编辑器。
|
||||||
|
|
||||||
|
不论编辑器有多么复杂,它们通常有一个共同的功能集,包括查找/替换文本,格式化文本,导入文件以及在文件中移动文本。
|
||||||
|
|
||||||
|
所有这些文本编辑器都是基于终端的应用,因此他们很适合在远程主机上编辑文件。文本编辑器通常也会提供一个图形化的用户界面,但依旧会保证快速和精简。
|
||||||
|
|
||||||
|
基于终端的应用程序在系统资源方面也是轻量级的(在低配置机器上很有用),比起它的图形化版本来也会更快、更高效,由于它们在X需要重启时也不会停止工作,因此非常适合编写脚本。
|
||||||
|
|
||||||
|
我选择了一些我最喜欢的开源文本编辑器,他们在使用系统资源方面都非常节俭。
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### Textadept ###
|
||||||
|
|
||||||
|
![](http://www.linuxlinks.com/portal/content/reviews/Editors/Screenshot-Textadept.png)
|
||||||
|
|
||||||
|
Textadept是一款适合程序员的,快速、精简、可扩展、跨平台的开源文本编辑器。这个开源程序由C和Lua写就,并且于这些年间在速度和精简方面进行了优化。
|
||||||
|
|
||||||
|
Textadept是那些想要无限的扩展性且不愿牺牲速度或屈服于代码膨胀的程序员们的理想编辑器。
|
||||||
|
|
||||||
|
它也有一个用于终端的版本,仅仅依赖ncurses,适合在远程主机上进行编辑。
|
||||||
|
|
||||||
|
#### 功能包括: ####
|
||||||
|
|
||||||
|
- 轻量级
|
||||||
|
- 精简设计以最大化利用屏幕
|
||||||
|
- 自包含的执行文件 - 无需安装
|
||||||
|
- 全键盘驱动
|
||||||
|
- 无限制的分割视图(GUI版本),以您所好任意水平或垂直的分割编辑器窗口。请注意Textadep不是一个选项卡式的编辑器。
|
||||||
|
- 支持多达80种的编程语言
|
||||||
|
- 强大的代码片段和快捷键命令
|
||||||
|
- 代码自动补全和API查询
|
||||||
|
- 无与伦比的扩展性
|
||||||
|
- 书签
|
||||||
|
- 查找和替换
|
||||||
|
- 在文件中查找
|
||||||
|
- 基于缓存的单词补全
|
||||||
|
- 成熟的编程语言符号自动补全,以及显示API文档的功能
|
||||||
|
- 主题:亮色、暗色、终端
|
||||||
|
- 使用词法分析器将名称放到缓冲中,如评论、字符串、关键词
|
||||||
|
- 支持会话
|
||||||
|
- 快速打开
|
||||||
|
- 许多可用的模块,包括对Java、Python、Ruby和近期打开文件列表的支持
|
||||||
|
- 符合Gnome HIG用户接口的指导
|
||||||
|
- 支持编辑Lua代码。许多Textadept对象和Lua的标准库支持语法自动补全和LuaDoc。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
- 网址: [foicica.com/textadept][1]
|
||||||
|
- 开发者: Mitchell and contributors
|
||||||
|
- 许可证: MIT License
|
||||||
|
- 版本号: 7.7
|
||||||
|
|
||||||
|
|
||||||
|
### Vim ###
|
||||||
|
|
||||||
|
![](http://www.linuxlinks.com/portal/content/reviews/Editors/Screenshot-vim.png)
|
||||||
|
|
||||||
|
vim是一个高级的文本编辑器,它在'vi'强大的基础上,并拥有更全面的功能集。
|
||||||
|
|
||||||
|
这个编辑器对编程和编辑其他纯ASCII的文件十分有用。所有的命令都由普通的键盘按键提供,能够使用十指来输入,因而十分快捷。另外,功能键可以由用户来定义,并且可也以使用鼠标。
|
||||||
|
|
||||||
|
Vim通常被称作"程序员的编辑器",它十分适合于编程,并被认为可以作为完整的集成开发环境。然而,这个软件并不是仅仅面向程序员。Vim适合于各种文本编辑,从编写email到修改配置文件。
|
||||||
|
|
||||||
|
Vim的界面基于文本界面下的命令行。尽管它的图形化版本gVim为常用的命令添加了菜单和工具栏,但这个软件的整个功能依旧依赖于它的命令行模式。
|
||||||
|
|
||||||
|
#### 功能包括: ####
|
||||||
|
|
||||||
|
- 3 种模式:
|
||||||
|
- 命令模式
|
||||||
|
- 插入模式
|
||||||
|
- 命令行模式
|
||||||
|
- 无限制的撤销
|
||||||
|
- 多个窗口和缓冲区
|
||||||
|
- 平滑的插入模式
|
||||||
|
- 根据所编辑的文件的类型使用不同的颜色或风格进行语法高亮
|
||||||
|
- 交互命令
|
||||||
|
- 标记一行
|
||||||
|
- vi 行缓冲
|
||||||
|
- 移动代码块
|
||||||
|
- 块操作
|
||||||
|
- 命令行历史
|
||||||
|
- 扩展的正则表达式
|
||||||
|
- 可编辑压缩/打包文件 (gzip, bzip2, zip, tar)
|
||||||
|
- 文件名补全
|
||||||
|
- 标记跳转
|
||||||
|
- 折叠文本
|
||||||
|
- 缩进
|
||||||
|
- ctags和cscope整合
|
||||||
|
- 100%与vi的模式兼容
|
||||||
|
- 插件用于添加/扩展功能
|
||||||
|
- 宏
|
||||||
|
- vimscript, Vim的内部脚本
|
||||||
|
- Unicode支持
|
||||||
|
- 多语言支持
|
||||||
|
- 在线帮助支持
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
- 网址: [www.vim.org][2]
|
||||||
|
- 开发者: Bram Moolenaar
|
||||||
|
- 许可证: GNU GPL compatible (charityware)
|
||||||
|
- 版本号: 7.4
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### ne ###
|
||||||
|
|
||||||
|
![](http://www.linuxlinks.com/portal/content/reviews/Editors/Screenshot-ne.png)
|
||||||
|
|
||||||
|
ne是一款全屏幕的开源文本编辑器。它像是一个比vi更容易学习的vi替代物,并且可以在POSIX-兼容的系统中便携使用。
|
||||||
|
|
||||||
|
ne对于新手来说易于使用,但也非常强大并有完全可配置的引导程序,并且在资源使用上十分节约。
|
||||||
|
|
||||||
|
#### 功能包括: ####
|
||||||
|
|
||||||
|
- 三种用户界面: 控制键,命令行、菜单;按键和菜单都可配置
|
||||||
|
- 语法高亮
|
||||||
|
- 对于UTF-8文件的完全支持,包括占据多列的字符(宽字符)
|
||||||
|
- 文档,剪切块,显示的维度和文件/行号长度都有编号,并且仅受制于机器的整型字长
|
||||||
|
- 简单的脚本语言,脚本可以用简单易理解的录制/播放的方式制作
|
||||||
|
- 无限制的撤销/重做功能(可以通过命令禁用)
|
||||||
|
- 基于被编辑的文件扩展名的自动个性化配置系统
|
||||||
|
- 使用您文档中的词语做字典来进行自动前缀补全
|
||||||
|
- 易用的文件存取功能
|
||||||
|
- 扩展的正则表达式可用于查找和替换,类似emacs和vi
|
||||||
|
- 非常紧凑的内存模型,在加载和修改大型文件时十分快速
|
||||||
|
- 可编辑二进制文件
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
- 网址: [ne.di.unimi.it][3]
|
||||||
|
- 开发者: Sebastiano Vigna (original developer). Additional features added by Todd M. Lewis
|
||||||
|
- 许可证: GNU GPL v3
|
||||||
|
- 版本号: 2.5
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
### Zile ###
|
||||||
|
|
||||||
|
![](http://www.linuxlinks.com/portal/content/reviews/Editors/Screenshot-Zile.png)
|
||||||
|
|
||||||
|
Zile(Zile Is Lossy Emacs,Emacs精简版),它是一个小型的Emacs的克隆版。Zile是一个可定制的,自文档化,实时显示的编辑器,Zile被开发的尽可能像Emacs一样,每个Emacs用户都会对Zile感到亲切。
|
||||||
|
|
||||||
|
Zile以它极小的RAM用量,大约130KB,以及快速开始编辑而闻名。它是支持8比特字符集的,允许用于编写任何种类的文件。
|
||||||
|
|
||||||
|
#### 功能包括: ####
|
||||||
|
|
||||||
|
- 小型但快速、强大
|
||||||
|
- 多个缓冲区,允许多级的撤销
|
||||||
|
- 多窗口
|
||||||
|
- 以最小的缓冲区完成补全
|
||||||
|
- 自动填充 (自动换行)
|
||||||
|
- Registers
|
||||||
|
- 看起来像Emacs,键序列、功能和变量名都与Emacs相同
|
||||||
|
- Killing
|
||||||
|
- Yanking
|
||||||
|
- 自动行末检测
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
- 网址: [www.gnu.org/software/zile][4]
|
||||||
|
- 开发者: Reuben Thomas, Sandro Sigala, David A. Capello
|
||||||
|
- 许可证: GNU GPL v2
|
||||||
|
- 版本号: 2.4.11
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### nano ###
|
||||||
|
|
||||||
|
![](http://www.linuxlinks.com/portal/content/reviews/Editors/Screenshot-nano.png)
|
||||||
|
|
||||||
|
nano是基于curses库的文本编辑器。它是Pico(Pine电子邮件客户端编辑器)的一个复刻版。
|
||||||
|
|
||||||
|
由于Pine套件的许可证问题诉讼案(Pine并未以开源许可证发布),并且也因为Pine缺少一些重要的功能,nano项目于1999年发起。
|
||||||
|
|
||||||
|
nano致力于赶上Pico的功能和其易用性,与此同时提供更多的功能,但不集成Pine/Pico的邮件客户端。
|
||||||
|
|
||||||
|
nano像Pico一样是以键盘为导向的设计,可以用控制键来控制。
|
||||||
|
|
||||||
|
#### 功能包括: ####
|
||||||
|
|
||||||
|
- 交互式的查找和替换
|
||||||
|
- 彩色语法高亮
|
||||||
|
- 转到行号和列号处
|
||||||
|
- 自动缩进
|
||||||
|
- 功能开关
|
||||||
|
- 支持UTF-8
|
||||||
|
- 混合型的文件类型自动转换
|
||||||
|
- 逐字输入模式
|
||||||
|
- 多个文件缓冲区
|
||||||
|
- 平滑滚动
|
||||||
|
- 括号匹配
|
||||||
|
- 自定义引用字符串
|
||||||
|
- 备份文件
|
||||||
|
- 国际化支持
|
||||||
|
- tab补全文件名
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
- 网址: [nano-editor.org][5]
|
||||||
|
- 开发者: Chris Allegretta, David Lawrence, Jordi Mallach, Adam Rogoyski, Robert Siemborski, Rocco Corsi, David Benbennick, Mike Frysinger
|
||||||
|
- 许可证: GNU GPL v3
|
||||||
|
- 版本号: 2.2.6
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.linuxlinks.com/article/20141011073917230/TextEditors.html
|
||||||
|
|
||||||
|
作者:Frazer Kline
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[1]:http://foicica.com/textadept/
|
||||||
|
[2]:http://www.vim.org/
|
||||||
|
[3]:http://ne.di.unimi.it/
|
||||||
|
[4]:http://www.gnu.org/software/zile/
|
||||||
|
[5]:http://nano-editor.org/
|
@ -0,0 +1,67 @@
|
|||||||
|
Linux下优秀的音频编辑软件
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
不论您是一个音乐爱好者或只是一个要记录您导师的讲话的学生,您都需要录制音频和编辑音频。长久以来这样的工作都要靠Macintosh,如今那个时代已经过去,现在Linux也可以胜任这些工作了。简而言之,这里有一份不完全的音频编辑器软件列表,适用于不同的任务和需求。
|
||||||
|
|
||||||
|
### 1. Audacity ###
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8572/15405018653_83ba3e718d_c.jpg)
|
||||||
|
|
||||||
|
让我们从我个人最喜欢的软件开始。[Audacity][1]可以运行在Windows、Mac和Linux上。它是开源的,且易于使用。你会觉得:Audacity几乎是完美的。它可以让您在干净的界面上操作音频波形。简单地说,您可以覆盖音轨、剪切和修改音轨、增加特效、执行高级的声音分析,然后将它们导出到一大堆可用的格式。我喜欢它的原因是它将基本的功能和复杂的功能结合在一起并且保持一个简单的学习曲线。然而,它并不是一个完全最优化的软件,尤其是对于音乐家和专业人员。
|
||||||
|
|
||||||
|
### 2. Jokosher ###
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7524/15998875136_82903a9b4a_c.jpg)
|
||||||
|
|
||||||
|
在不同的层次上,[Jokosher][2]更多的聚焦在多音轨方面。它使用Python和GTK+作为前端界面,并使用GStreamer作为音频后端。Jokosher那易用的界面和它的扩展性给我留下了深刻的印象。也许编辑的功能并不是最先进的,但它的提示十分清晰,适合音乐家。例如,我十分喜欢音轨和乐器的组合。简而言之,如果您是一个音乐家,那么它是在您转移到下一个软件前进行实践的好机会。
|
||||||
|
|
||||||
|
### 3. Ardour ###
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8577/16024644385_d8cd8073a3_c.jpg)
|
||||||
|
|
||||||
|
接下来谈论一些复杂的工具,[Ardour][3]是一套完整的可以录制、编辑和混音的软件。这个设计吸引了所有的专业人员,Ardour在声音和插件方面超出我的想象。如果您在寻找一头野兽并且不惧怕驯服它,那么Ardour或许是一个不错的选择。再次,它的界面和丰富的文档,尤其是它首次启动时的配置工具都是它迷人魅力的一部分。
|
||||||
|
|
||||||
|
### 4. Kwave ###
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7557/15402389884_633a8b04c5_c.jpg)
|
||||||
|
|
||||||
|
对于所有KDE的热爱者,[KWave][4]绝对符合您对于设计和功能的想象。它有丰富的快捷键以及很多有趣的选项,例如内存管理。尽管很多特效很不错,但我们更应该关注那些用于音频剪切/粘贴的工具。可惜的是它无法与Audacity相比,而更重要的是,它的界面并没有那么吸引我。
|
||||||
|
|
||||||
|
### 5. Qtractor ###
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7551/16022707501_68c39f37e5_c.jpg)
|
||||||
|
|
||||||
|
如果Kwave对您来说过于简单,但基于Qt的程序却有些吸引力,那么对您来说,也许[Qtractor][5]是一个选项。它致力于做一个“对于家庭用户来说足够简单,并且对专业人员来说足够强大的软件。”实际上它功能和选项的数量几乎是压倒性的。我最喜欢的当然是可定制的快捷键。除此之外,Qtractor可能是我最喜欢的一个处理MIDI文件的工具。
|
||||||
|
|
||||||
|
### 6. LMMS ###
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7509/15838603239_ef0ecbc8d2_c.jpg)
|
||||||
|
|
||||||
|
作为Linux多媒体工作室,LMMS的直接目标是音乐制作。如果您之前没有什么经验并且不想浪费太多的时间,那么请去别处吧。LMMS是其中一个复杂但强大的软件,只有少数的人真正的掌握了它。它有太多的功能和特效以至于无法一一列出,但如果我必须找一个,我会说用来模拟Game Boy声音系统的Freeboy插件简直像魔术一样。然后,去看看它那惊人的文档吧。
|
||||||
|
|
||||||
|
### 7. Traverso ###
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7537/15838603279_70ee925057_c.jpg)
|
||||||
|
|
||||||
|
最后站在我面前的是Traverso,它支持无限制的音轨计数,并直接整合了CD烧录的功能。另外,它对我来说是介于简单的软件和专业的软件之间的程序。它的界面是KDE样式的,其键盘配置很简单。更有趣的是,Traverso会监视您的系统资源以确定不会超过您的CPU或者硬件的能力。
|
||||||
|
|
||||||
|
总而言之,能在Linux系统上看到这么多不同的应用程序是一件开心的事。它使得您永远可以找到最适合自己的那一款。虽然我最喜欢的应用是Audacity,但我非常震惊于LMMS和Jokosher的设计。
|
||||||
|
|
||||||
|
我们有漏掉什么么?您在Linux下使用哪一款软件呢?原因是什么呢?请留言让我们知道。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/good-audio-editing-software-linux.html
|
||||||
|
|
||||||
|
作者:[Adrien Brochard][a]
|
||||||
|
译者:[wwy-hust](https://github.com/wwy-hust)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/adrien
|
||||||
|
[1]:http://audacity.sourceforge.net/
|
||||||
|
[2]:https://launchpad.net/jokosher/
|
||||||
|
[3]:http://ardour.org/
|
||||||
|
[4]:http://kwave.sourceforge.net/
|
||||||
|
[5]:http://qtractor.sourceforge.net/qtractor-index.html
|
@ -0,0 +1,187 @@
|
|||||||
|
Linux中安装Cisco Packet Tracer
|
||||||
|
================================================================================
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/Main_picture.png)
|
||||||
|
|
||||||
|
### Cisco Packet tracer是什么? ###
|
||||||
|
|
||||||
|
**Cisco Packet Tracer**是一个强大的网络模拟工具,用于进行Cisco认证时的培训。它为我们提供了各个路由器和网络设备的良好的接口视图,这些模拟设备带有很多选项,跟使用物理机一样,我们可以在网络中使用无限的设备。我们能在单个工程中创建多个网络,以获得专业化的训练。Packet Tracer将提供给我们模拟的应用层协议,如**HTTP**,**DNS**,以及像**RIP**,**OSPF**,**EIGRP**等路由协议。
|
||||||
|
|
||||||
|
现在,它发布了包含有**ASA 5505防火墙**命令行配置的版本。Packet Tracer通常用于Windows版本,但没有Linux版本。这里,我们可以下载并安装Cisco Packet Tracer。
|
||||||
|
|
||||||
|
#### 新发布的Cisco Packet Tracer版本: ####
|
||||||
|
|
||||||
|
下一代Cisco Packet Tracer版本将会是Cisco Packet Tracer 6.2,当前还处于开发中。
|
||||||
|
|
||||||
|
### 我的环境设置: ###
|
||||||
|
|
||||||
|
**主机名** : desktop1.unixmen.com
|
||||||
|
|
||||||
|
**IP地址** : 192.168.0.167
|
||||||
|
|
||||||
|
**操作系统** : Ubuntu 14.04 LTS Desktop
|
||||||
|
|
||||||
|
# hostname
|
||||||
|
|
||||||
|
# ifconfig | grep inet
|
||||||
|
|
||||||
|
# lsb_release -a
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_001.png)
|
||||||
|
|
||||||
|
### 步骤 1: 首先,我们需要下载Cisco Packet Tracer。 ###
|
||||||
|
|
||||||
|
要从官方网站下载Packet Tracer,我们需要持有一个令牌,登入Cisco NetSpace,然后从Offering菜单选择CCNA > Cisco Packet Tracer来开始下载。如果我们没有令牌,可以从下面的链接中获得,我已经将它上传到了Droppox。
|
||||||
|
|
||||||
|
官方站点: [https://www.netacad.com/][1]
|
||||||
|
|
||||||
|
大多数人没有下载Packet Tracer的令牌,出于该原因,我已经将它上传到了dropbox,你可以从下面的URL获得Packet Tracer。
|
||||||
|
|
||||||
|
[下载Cisco Packet Tracer 6.1.1][2]
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_002.png)
|
||||||
|
|
||||||
|
### 步骤 2: 安装Java: ###
|
||||||
|
|
||||||
|
要安装Packet Tracer,我们需要安装java。我们可以使用默认的仓库安装java;或者添加PPA仓库,然后更新包缓存来安装java。
|
||||||
|
|
||||||
|
使用以下命令来安装默认的jre
|
||||||
|
|
||||||
|
# sudo apt-get install default-jre
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_003.png)
|
||||||
|
|
||||||
|
(或者)
|
||||||
|
|
||||||
|
使用下面的步骤来安装Java Run-time并设置环境。
|
||||||
|
|
||||||
|
从官方站点下载Java:[下载Java][3]
|
||||||
|
|
||||||
|
# tar -zxvf jre-8u31-linux-x64.tar.gz
|
||||||
|
# sudo mkdir -p /usr/lib/jvm
|
||||||
|
# sudo mv -v jre1.8.0_31 /usr/lib/jvm/
|
||||||
|
# cd /usr/lib/jvm/
|
||||||
|
# sudo update-alternatives --install "/usr/bin/java" "java" "/usr/lib/jvm/jre1.8.0_31/bin/java" 1
|
||||||
|
# sudo update-alternatives --set "java" "/usr/lib/jvm/jre1.8.0_31/bin/java"
|
||||||
|
|
||||||
|
通过编辑用户参数文件来设置Java环境,并添加路径相关的参数。当我们添加进用户参数文件后,我们机器上的每个用户都可以用java了。
|
||||||
|
|
||||||
|
# sudo vi /etc/profile
|
||||||
|
|
||||||
|
将以下条目添加到/etc/profile文件中:
|
||||||
|
|
||||||
|
export JAVA_HOME=/usr/lib/jvm/jre1.8.0_31
|
||||||
|
export PATH=$PATH:/usr/java/jre1.8.0_31/bin
|
||||||
|
|
||||||
|
运行以下命令来立即激活java路径。
|
||||||
|
|
||||||
|
# . /etc/profile
|
||||||
|
|
||||||
|
检查Java版本和环境:
|
||||||
|
|
||||||
|
# echo $JAVA_HOME
|
||||||
|
# java -version
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_004.png)
|
||||||
|
|
||||||
|
### 步骤 3: 启用32位架构支持: ###
|
||||||
|
|
||||||
|
对于Packet Tracer,我们需要一些32位包。要安装32位包,我们需要使用以下命令来安装一些依赖。
|
||||||
|
|
||||||
|
# sudo dpkg --add-architecture i386
|
||||||
|
# sudo apt-get update
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_005.png)
|
||||||
|
|
||||||
|
# sudo apt-get install libc6:i386
|
||||||
|
# sudo apt-get install lib32z1 lib32ncurses5 lib32bz2-1.0
|
||||||
|
# sudo apt-get install libnss3-1d:i386 libqt4-qt3support:i386 libssl1.0.0:i386 libqtwebkit4:i386 libqt4-scripttools:i386
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_006.png)
|
||||||
|
|
||||||
|
### 步骤 4: 解压并安装软件包: ###
|
||||||
|
|
||||||
|
使用tar命令来解压下载的包。
|
||||||
|
|
||||||
|
# mv Cisco\ Packet\ Tracer\ 6.1.1\ Linux.tar.gz\?dl\=0 Cisco_Packet_tracer.tar.gz
|
||||||
|
|
||||||
|
# tar -zxvf Cisco_Packet_tracer.tar.gz
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_007.png)
|
||||||
|
|
||||||
|
导航到解压后的目录
|
||||||
|
|
||||||
|
# cd PacketTracer611Student
|
||||||
|
|
||||||
|
现在,该开始安装了。安装过程很简单,只需几秒钟即可搞定。
|
||||||
|
|
||||||
|
# sudo ./install
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_008.png)
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_009.png)
|
||||||
|
|
||||||
|
要使用Packet Tracer工作,我们需要设置环境,Cisco已经提供了环境脚本,我们需要以root用户来运行该脚本以设置环境变量。
|
||||||
|
|
||||||
|
# sudo ./set_ptenv.sh
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_010.png)
|
||||||
|
|
||||||
|
安装到此结束。接下来,我们需要为Packet Tracer创建桌面图标。
|
||||||
|
|
||||||
|
通过创建下面的桌面文件来创建桌面图标。
|
||||||
|
|
||||||
|
# sudo su
|
||||||
|
# cd /usr/share/applications
|
||||||
|
# sudo vim packettracer.desktop
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_011.png)
|
||||||
|
|
||||||
|
使用vim编辑器或你喜爱的那个编辑器来添加以下内容到文件。
|
||||||
|
|
||||||
|
[Desktop Entry]
|
||||||
|
Name= Packettracer
|
||||||
|
Comment=Networking
|
||||||
|
GenericName=Cisco Packettracer
|
||||||
|
Exec=/opt/packettracer/packettracer
|
||||||
|
Icon=/usr/share/icons/packettracer.jpeg
|
||||||
|
StartupNotify=true
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
|
||||||
|
使用wq!来保存并退出vim。
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_012.png)
|
||||||
|
|
||||||
|
### 步骤 5: 运行Packet Tracer ###
|
||||||
|
|
||||||
|
# sudo packettracer
|
||||||
|
|
||||||
|
好了,我们已经成功将Packet Tracer安装到Linux中。上述安装步骤适用于所有基于Debian的Linux发行版。
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_013.png)
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/pkt_014.png)
|
||||||
|
|
||||||
|
### 资源 ###
|
||||||
|
|
||||||
|
主页:[Netacad][4]
|
||||||
|
|
||||||
|
### 尾声: ###
|
||||||
|
|
||||||
|
这里,我们展示了如何安装Packet Tracer到Linux发行版中。希望你们找到了将你们所钟爱的模拟器安装到Linux中的方法。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.unixmen.com/installing-cisco-packet-tracer-linux/
|
||||||
|
|
||||||
|
作者:[babin][a]
|
||||||
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.unixmen.com/author/babin/
|
||||||
|
[1]:https://www.netacad.com/
|
||||||
|
[2]:https://www.dropbox.com/s/5evz8gyqqvq3o3v/Cisco%20Packet%20Tracer%206.1.1%20Linux.tar.gz?dl=0
|
||||||
|
[3]:http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html
|
||||||
|
[4]:https://www.netacad.com/
|
@ -0,0 +1,64 @@
|
|||||||
|
iptraf:TCP/UDP网络监控工具
|
||||||
|
================================================================================
|
||||||
|
[iptraf][1]是一个基于ncurses开发的IP局域网监控工具,它可以生成各种网络统计数据,包括TCP信息、UDP统计、ICMP和OSPF信息、以太网负载信息、节点统计、IP校验和错误和其它一些信息。
|
||||||
|
|
||||||
|
它基于ncurses的用户界面也会把使用者从命令行选项的梦靥中拯救出来。
|
||||||
|
|
||||||
|
### 功能 ###
|
||||||
|
|
||||||
|
- 一个用于显示通过网络的IP流量信息的IP流量监控器,包括TCP标识信息、包和字节统计、ICMP详情、OSPF包类型
|
||||||
|
- 显示IP、TCP、UDP、ICMP、非IP和其它IP包计数、IP校验和错误、接口活动、包大小计数的综合详细的接口统计数据
|
||||||
|
- 一个用于计数常用TCP和UDP应用端口的流入和流出包的TCP和UDP服务监控器
|
||||||
|
- 一个用于发现活动主机和显示这些活动主机的数据活动的局域网统计模块
|
||||||
|
- TCP、UDP和其它协议的显示过滤器,允许你查看你做感兴趣的流量
|
||||||
|
- 日志记录
|
||||||
|
- 支持以太网、FDDI、ISDN、SLIP、PPP和回环接口类型
|
||||||
|
- 利用Linux内核内建的原生套接口界面,可以用于大范围支持的网卡
|
||||||
|
- 全屏、菜单驱动操作
|
||||||
|
|
||||||
|
###要安装###
|
||||||
|
|
||||||
|
**Ubuntu及其衍生版**
|
||||||
|
|
||||||
|
sudo apt-get install iptraf
|
||||||
|
|
||||||
|
**Arch Linux及其衍生版**
|
||||||
|
|
||||||
|
sudo pacman -S iptra
|
||||||
|
|
||||||
|
**Fedora及其衍生版**
|
||||||
|
|
||||||
|
sudo yum install iptraf
|
||||||
|
|
||||||
|
### 用法 ###
|
||||||
|
|
||||||
|
如果**iptraf**命令不带任何命令行选项执行,该程序就会以交互模式显现,可以通过主菜单获得各种各样的工具。
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/iptraf_1.png)
|
||||||
|
|
||||||
|
易于导航的菜单。
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/iptraf_2.png)
|
||||||
|
|
||||||
|
选择监控的接口。
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/iptraf_3.png)
|
||||||
|
|
||||||
|
来自**ppp0**接口的流量
|
||||||
|
|
||||||
|
![](http://1102047360.rsc.cdn77.org/wp-content/uploads/2015/01/iptraf_4.png)
|
||||||
|
|
||||||
|
希望你喜欢。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.unixmen.com/iptraf-tcpudp-network-monitoring-utility/
|
||||||
|
|
||||||
|
作者:[Enock Seth Nyamador][a]
|
||||||
|
译者:[GOLinux](https://github.com/GOLinux)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.unixmen.com/author/seth/
|
||||||
|
[1]:http://iptraf.seul.org/about.html
|
@ -0,0 +1,154 @@
|
|||||||
|
2015 年度开源项目新秀榜
|
||||||
|
================================================================================
|
||||||
|
黑鸭(Black Duck)软件公布了一份名叫“年度开源项目新秀”的报告,介绍了由全球开源协会发起的10个最有趣、最活跃的新项目。
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_01-100564902-orig.jpeg)
|
||||||
|
|
||||||
|
### 年度开源项目新秀 ###
|
||||||
|
|
||||||
|
每年都有上千新的开源项目问世,但只有少数能够真正的吸引我们的关注。一些项目因为利用了当前比较流行的技术而发展壮大,有一些则真正地开启了一个新的领域。很多开源项目建立的初衷是为了解决一些生产上的问题,还有一些项目则是世界各地志同道合的开发者们共同发起的一个宏伟项目。
|
||||||
|
|
||||||
|
从2009年起,开源软件管理公司黑鸭便发起了[年度开源项目新秀][1]这一活动,它的评选根据[Open Hub][2]网站(即以前的Ohloh)上的活跃度。今年,我们很荣幸能够报道2015年10大开源项目新秀的得主和2名荣誉奖得主,它们是从上千个开源项目中脱颖而出的。评选采用了加权评分系统,得分标准基于项目的活跃度,交付速度和几个其它因数。
|
||||||
|
|
||||||
|
开源俨然成为了产业创新的引擎,就拿今年来说,和Docker容器相关的开源项目在全球各地兴起,这也不恰巧反映了企业最感兴趣的技术领域吗?最后,我们接下来介绍的项目,将会让你了解到全球开源项目的开发者们的在思考什么,这很快将会成为一个指引我们发展的领头羊。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: DebOps ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_02-100564903-orig.jpeg)
|
||||||
|
|
||||||
|
[DebOps][3]收集打包了一套[Ansible][4]方案和规则(Ansible是一种自动化运维工具),可以从1个容器扩展到一个完整的数据中心。它的创始人Maciej Delmanowski将DebOps开源来保证项目长久进行,从而更好的通过外部贡献者的帮助发展下去。
|
||||||
|
|
||||||
|
DebOps始创于波兰的一个不起眼大学校园里,他们运营自己的数据中心,一切工作都采用手工配置。有时系统崩溃而导致几天的宕机,这时Delmanowski意识到一个配置管理系统是很有必要的。以Debian作为基础开始,DebOps是一组配置一整个数据基础设施的Ansible方案。此项目已经在许多不同的工作环境下实现,而创始者们则打算继续支持和改进这个项目。
|
||||||
|
|
||||||
|
###2015年度开源项目新秀: Code Combat ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_03-100564904-gallery.idge.jpg)
|
||||||
|
|
||||||
|
传统的纸笔学习方法已近不能满足技术学科了。然而游戏却有很多人都爱玩,这也就是为什么[CodeCombat][5]的创始人会去开发一款多人协同编程游戏来教人们如何编码。
|
||||||
|
|
||||||
|
刚开始CodeCombat是一个创业想法,但其创始人决定取而代之创建一个开源项目。此想法在社区传播开来,很快不少贡献者加入到项目中来。项目发起仅仅两个月后,这款游戏就被接纳到Google’s Summer of Code活动中。这款游戏吸引了大量玩家,并被翻译成45种语言。CodeCombat希望成为那些想要一边学习代码同时获得乐趣的同学的风向标。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: Storj ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_04-100564905-gallery.idge.jpg)
|
||||||
|
|
||||||
|
[Storj][6]是一个点对点的云存储网络,可实现端到端加密,保证用户不用依赖第三方即可传输和共享数据。基于比特币block chain技术和点对点协议,Storj提供安全、私密、加密的云存储。
|
||||||
|
|
||||||
|
云数据存储的反对者担心成本开销和漏洞攻击。针对这两个担忧,Storj提供了一个私有云存储市场,用户可以通过Storjcoin X(SJCX) 购买交易存储空间。上传到Storj的文件会被粉碎、加密和存储到整个社区。只有文件所有者拥有密钥加密的信息。
|
||||||
|
|
||||||
|
在2014年举办的Texas Bitcoin Conference Hackathon会议上,去中心化的云存储市场概念首次被提出并证明可行。在第一次赢得黑客马拉松活动后,项目创始人们和领导团队利用开放论坛、Reddit、比特币论坛和社交媒体增长成了一个活跃的社区,如今,它们已成为影响Storj发展方向的一个重要组成部分。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: Neovim ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_05-100564906-orig.jpg)
|
||||||
|
|
||||||
|
自1991年出现以来,Vim已经成为数以百万计软件开发人员所钟爱的文本编辑器。 而[Neovim][6]就是它的下一个版本。
|
||||||
|
|
||||||
|
在过去的23年里,软件开发生态系统经历了无数增长和创新。Neovim创始人Thiago de Arruda认为Vim缺乏当代元素,跟不上时代的发展。在保留Vim的招牌功能的前提下,Neovim团队同样在寻求改进和发展这个最受欢迎的文本编辑器的技术。早期众筹让Thiago de Arruda可以连续6个月时间投入到此项目。他相信Neovim社区会支持这个项目,激励他继续开发Neovim。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: CockroachDB ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_06-100564907-orig.jpg)
|
||||||
|
|
||||||
|
前谷歌员工开发了一个开源的大型企业数据存储项目[CockroachDB][8],它是一个可扩展的、跨地域复制且支持事务的数据存储的解决方案。
|
||||||
|
|
||||||
|
为了保证在线的百万兆字节流量业务的质量,Google开发了Spanner系统,这是一个可扩展的,稳定的,支持事务的系统。许多参与开发CockroachDB的团队现在都服务于开源社区。就像真正的蟑螂(cockroach)一样,CockroachDB可以在没有数据头、任意节点失效的情况下正常运行。这个开源项目有很多富有经验的贡献者,创始人们通过社交媒体、Github、网络、会议和聚会结识他们并鼓励他们参与其中。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: Kubernetes ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_07-100564908-orig.jpg)
|
||||||
|
|
||||||
|
在将容器化软件到引入开源社区发展时,[Docker][9]是一匹黑马,它创新了一套技术和工具。去年6月谷歌推出了[Kubernetes][10],这是一款开源的容器管理工具,用来加快开发和简化操作。
|
||||||
|
|
||||||
|
谷歌在它的内部运营上使用容器技术多年了。在2014年夏天的DockerCon上大会上,谷歌这个互联网巨头开源了Kubernetes,Kubernetes的开发是为了满足迅速增长的Docker生态系统的需要。通过和其它的组织、项目合作,比如Red Hat和CoreOS,Kubernetes项目的管理者们推动它登上了Docker Hub的工具下载榜榜首。Kubernetes的开发团队希望扩大这个项目,发展它的社区,这样的话软件开发者就能花更少的时间在管理基础设施上,而更多的去开发他们自己的APP。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: Open Bazaar ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_08-100564909-orig.jpg)
|
||||||
|
|
||||||
|
OpenBazaar是一个使用比特币与其他人交易的去中心化的市场。OpenBazaar这一概念最早在编程马拉松(hackathon)活动中被提出,它的创始人结合了BitTorent、比特币和传统的金融服务方式,创造了一个不受审查的交易平台。OpenBazaar的开发团队在寻求新的成员,而且不久以后他们将极度扩大Open Bazaar社区。Open Bazaar的核心是透明度,其创始人和贡献者的共同目标是在商务交易中掀起一场革命,让他们向着一个真实的、一个无控制的,去中心化的市场奋进。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: IPFS ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_09-100564910-orig.jpg)
|
||||||
|
|
||||||
|
IPFS 是一个面向全球的、点对点的分布式版本文件系统。它综合了Git,BitTorrent,HTTP的思想,开启了一个新的数据和数据结构传输协议。
|
||||||
|
|
||||||
|
人们所知的开源,它的本意用简单的方法解决复杂的问题,这样产生许多新颖的想法,但是那些强大的项目仅仅是开源社区的冰山一角。IFPS有一个非常激进的团队,这个概念的提出是大胆的,令人惊讶的,有点甚至高不可攀。看起来,一个点对点的分布式文件系统是在寻求将所有的计算设备连在一起。这个可能的 HTTP 替换品通过多种渠道维护着一个社区,包括Git社区和超过100名贡献者的IRC。这个疯狂的想法将在2015年进行软件内部测试。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: cAdvisor ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_10-100564911-orig.jpg)
|
||||||
|
|
||||||
|
[cAdvisor (Container Advisor)][13] 是一个针对在运行中的容器进行收集,统计,处理和输出信息的工具,它可以给容器的使用者提供资源的使用情况和工作特性。对于每一个容器,cAdvisor记录着资源的隔离参数,资源使用历史,资源使用历史对比框图,网络状态。这些从容器输出的数据跨越主机传递。
|
||||||
|
|
||||||
|
cAdvisor可以在绝大多数的Linux发行版上运行,并且支持包括Docker在内的多种容器类型。事实上它成为了一种容器的代理,并被集成在了很多系统中。cAdvisor在DockerHub下载量也是位居前茅。cAdvisor的开发团队希望把cAdvisor改进到能够更深入地理解应用性能,并且集成到集群系统。
|
||||||
|
|
||||||
|
### 2015年度开源项目新秀: Terraform ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_11-100564912-orig.jpg)
|
||||||
|
|
||||||
|
[Terraform][14]提供了一些常见设置来创建一个基础设施,从物理机到虚拟机,以及email服务器、DNS服务器等。这个想法包括从家庭个人机解决方案到公共云平台提供的服务。一旦建立好了以后,Terraform可以让运维人员安全又高效地改变你的基础设施,就如同配置一样。
|
||||||
|
|
||||||
|
Terraform.io的创始者工作在一个Devops模式的公司,他找到了一个窍门把建立一个完整的数据中心所需的知识结合在一起,可以从添加服务器到支持网络服务的功能齐备的数据中心。基础设施的描述采用高级的配置语法,允许你把数据中心的蓝图按版本管理,并且转换成多种代码。著名开源公司HashiCorp赞助开发这个项目。
|
||||||
|
|
||||||
|
### 荣誉奖: Docker Fig ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_12-100564913-orig.jpg)
|
||||||
|
|
||||||
|
[Fig][15]为[Docker][16]的使用提供了一个快速的,分离的开发环境。Docker的移植只需要将配置信息放到一个简单的 fig.yml文件里。它会处理所有工作,包括构建、运行,端口转发,分享磁盘和容器链接。
|
||||||
|
|
||||||
|
Orchard去年发起了Fig,来创造一个使Docker工作起来的系统工具。它的开发像是为Docker设置开发环境,为了确保用户能够为他们的APP准确定义环境,在Docker中会运行数据库和缓存。Fig解决了开发者的一个难题。Docker全面支持这个开源项目,最近[将买下][17]Orchard来扩张这个项目。
|
||||||
|
|
||||||
|
### 荣誉奖: Drone ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_13-100564916-orig.jpg)
|
||||||
|
|
||||||
|
[Drone][18]是一个基于Docker的持续集成平台,而且它是用Go语言写的。Drone项目不满于现存的设置开发环境的技术和流程。
|
||||||
|
|
||||||
|
Drone提供了一个简单的自动测试和持续交付的方法:简单选择一个Docker镜像来满足你的需求,连接并提交至GitHub即可。Drone使用Docker容器来提供隔离的测试环境,让每个项目完全自主控制它的环境,没有传统的服务器管理的负担。Drone背后的100位社区贡献者强烈希望把这个项目带到企业和移动应用程序开发中。
|
||||||
|
|
||||||
|
### 开源新秀 ###
|
||||||
|
|
||||||
|
![](http://images.techhive.com/images/article/2015/01/open_source_rookies_14-100564941-orig.jpg)
|
||||||
|
|
||||||
|
参见:
|
||||||
|
|
||||||
|
- [InfoWorld2015年年度技术奖][21]
|
||||||
|
- [Bossies: 开源软件最高荣誉][22]
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://www.infoworld.com/article/2875439/open-source-software/the-top-10-rookie-open-source-projects.html
|
||||||
|
|
||||||
|
作者:[Black Duck Software][a]
|
||||||
|
译者:[sevenot](https://github.com/sevenot)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://www.infoworld.com/author/Black-Duck-Software/
|
||||||
|
[1]:https://www.blackducksoftware.com/open-source-rookies
|
||||||
|
[2]:https://www.openhub.net/
|
||||||
|
[3]:https://github.com/debops/debops
|
||||||
|
[4]:http://www.infoworld.com/article/2612397/data-center/review--ansible-orchestration-is-a-veteran-unix-admin-s-dream.html
|
||||||
|
[5]:https://codecombat.com/
|
||||||
|
[6]:http://storj.io/
|
||||||
|
[7]:http://neovim.org/
|
||||||
|
[8]:https://github.com/cockroachdb/cockroach
|
||||||
|
[9]:http://www.infoworld.com/resources/16373/application-virtualization/the-beginners-guide-to-docker
|
||||||
|
[10]:http://kubernetes.io/
|
||||||
|
[11]:https://openbazaar.org/
|
||||||
|
[12]:http://ipfs.io/
|
||||||
|
[13]:https://github.com/google/cadvisor
|
||||||
|
[14]:https://www.terraform.io/
|
||||||
|
[15]:http://www.fig.sh/
|
||||||
|
[16]:http://www.infoworld.com/resources/16373/application-virtualization/the-beginners-guide-to-docker
|
||||||
|
[17]:http://www.infoworld.com/article/2608546/application-virtualization/docker-acquires-orchard-in-a-sign-of-rising-ambitions.html
|
||||||
|
[18]:https://drone.io/
|
||||||
|
[19]:http://www.infoworld.com/article/2683845/google-go/164121-Fast-guide-to-Go-programming.html
|
||||||
|
[20]:https://www.blackducksoftware.com/open-source-rookies
|
||||||
|
[21]:http://www.infoworld.com/article/2871935/application-development/infoworlds-2015-technology-of-the-year-award-winners.html
|
||||||
|
[22]:http://www.infoworld.com/article/2688104/open-source-software/article.html
|
||||||
|
[23]:http://www.infoworld.com/article/2854954/microsoft-windows/15-essential-open-source-tools-for-windows-admins.html
|
||||||
|
|
@ -0,0 +1,111 @@
|
|||||||
|
在 Linux 上如何用命令行获取 Freely RSS 源
|
||||||
|
================================================================================
|
||||||
|
|
||||||
|
也许你并不知道 Feedly,它是世界上最流行的在线新闻聚合服务之一;它提供了平滑而一致的新闻阅读体验,你可以使用电脑的浏览器扩展,Android 和 iOS 设备上的移动应用程序等来体验Feedly。Feedly 在2013年Google Reader 停用后,迅速的获得了一大批Google Reader的用户。我就是他们之中的一位。从这以后,Feedly就一直是我的默认RSS(简易信息聚合)阅读器。
|
||||||
|
|
||||||
|
除了使用我非常喜欢的Feedly浏览器扩展和手机上的Feedly程序,这里还有一种途径来获取Feedly:Linux命令行。没错,你可以用命令行来获取Feedly上的新闻概要。听起来非常傻?但是对于那些在服务器上工作的系统管理员来说,这是非常有用的。
|
||||||
|
|
||||||
|
点击进入[Feednix][2],这个用c++编写的开源软件是Feedly的非官方命令行客户端。它允许你在一个基于ncurses的终端界面(例如:bash)下浏览Feedly的新闻。默认模式下,Feednix 关联了一个叫做 w3m 的基于控制台的浏览器,允许你在命令行终端的环境下阅读文章。当然你也可以选择使用你喜欢的网页浏览器。
|
||||||
|
|
||||||
|
在这个教程中,我准备示范一下怎样在命令行下安装和配置Feednix 来获取Feedly。
|
||||||
|
|
||||||
|
### 在Linux下安装Feednix ###
|
||||||
|
|
||||||
|
你可以通过以下的步骤从源代码中构建Feednix。同时,在其官方的github仓库的Ubuntu-stable(Ubuntu稳定版本)的分支上有最新的Feednix源代码。现在让我们开始吧:
|
||||||
|
|
||||||
|
作为必要组件,你需要安装一组开发包,和w3m浏览器(文字式页面浏览器)。
|
||||||
|
|
||||||
|
#### 在Debian、Ubuntu 和Linux Mint 操作 ####
|
||||||
|
|
||||||
|
$ sudo apt-get install git automake g++ make libncursesw5-dev libjsoncpp-dev libcurl4-gnutls-dev w3m
|
||||||
|
$ git clone -b Ubuntu-stable https://github.com/Jarkore/Feednix.git
|
||||||
|
$ cd Feednix
|
||||||
|
$ ./autogen.sh
|
||||||
|
$ ./configure
|
||||||
|
$ make
|
||||||
|
$ sudo make install
|
||||||
|
|
||||||
|
|
||||||
|
#### 在Fedora 下操作 ####
|
||||||
|
|
||||||
|
$ sudo yum groupinstall "C Development Tools and Libraries"
|
||||||
|
$ sudo yum install gcc-c++ git automake make ncurses-devel jsoncpp-devel libcurl-devel w3m
|
||||||
|
$ git clone -b Ubuntu-stable https://github.com/Jarkore/Feednix.git
|
||||||
|
$ cd Feednix
|
||||||
|
$ ./autogen.sh
|
||||||
|
$ ./configure
|
||||||
|
$ make
|
||||||
|
$ sudo make install
|
||||||
|
|
||||||
|
#### Arch Linux ####
|
||||||
|
|
||||||
|
在Arch Linux发行版下,你可以非常容易的从 [AUR][3]安装Feednix。
|
||||||
|
|
||||||
|
### 配置Feednix ###
|
||||||
|
|
||||||
|
在安装完软件后,用下面的命令启动Feednix
|
||||||
|
|
||||||
|
$ feednix
|
||||||
|
|
||||||
|
如果你是第一次运行Feddnix,它会弹出一个网页浏览器窗口,在这个窗口里,你需要登录来创建一个Feedly的账户ID和相应的开发人员密钥。
|
||||||
|
|
||||||
|
如果你是在无桌面环境下运行Feednix,先在另外一台电脑上打开一个网页,进入到网站:https://feedly.com/v3/auth/dev 。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7427/15825106524_42883b3e32_b.jpg)
|
||||||
|
|
||||||
|
当你登录后,你对应的Feedly账户ID就生成了。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8565/15827565143_eb93db9c81_b.jpg)
|
||||||
|
|
||||||
|
为了得到一个访问密钥,你需要在浏览器上访问发送你的邮箱中的密钥链接。之后就会在浏览器窗口显示你的用户ID,密钥,和密钥的有效期。请注意密钥的长度是非常长的(超过200个字符),所以密钥显示在一个带有垂直滚动条的文本框内,请确保把整个密钥复制下来。
|
||||||
|
|
||||||
|
![](https://farm9.staticflickr.com/8605/16446685812_9098df494b_b.jpg)
|
||||||
|
|
||||||
|
像下面这样,把你的用户ID和密钥输入到Feddnix的命令行提示下:
|
||||||
|
|
||||||
|
[Enter User ID] >> XXXXXX
|
||||||
|
[Enter token] >> YYYYY
|
||||||
|
|
||||||
|
成功授权后,你会在屏幕上见到一个初始化为两个窗格的Feednix界面。左边的标题为“Categories”窗格,显示了一个新闻分类栏;右边“Posts”窗格显示了当前类别的新闻文章。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7412/16421639256_deb8e2d276_c.jpg)
|
||||||
|
|
||||||
|
### 用Feednix读文章 ###
|
||||||
|
|
||||||
|
这里我想简要描叙一下怎样通过Feednix来访问Feedly。
|
||||||
|
|
||||||
|
#### 在Feednix中导航 ####
|
||||||
|
|
||||||
|
像我之前提过的,Feednix窗口包含了两个窗格。想在两个窗口之间进行切换的话,可以使用"TAB"健。想在一个窗格内的列表中上下移动,可以使用"j"和"k"。这些快捷健明显是受到了Vim编辑器的启发。
|
||||||
|
|
||||||
|
#### 阅读文章 ####
|
||||||
|
|
||||||
|
想阅读一篇特定的文章,可以在当前的文章上使用"o"健。它会调用w3m浏览器,并且在浏览器里面加载文章。当你读完之后,可以使用"q"健来退出浏览器,并返回到Feednix。如果你的电脑环境允许打开网页浏览器,你可以按"0"健来在你默认的网页浏览器里面加载文章,比如使用Firefox。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7406/16445870201_b98e8da6d9_b.jpg)
|
||||||
|
|
||||||
|
#### 订阅新闻源 ####
|
||||||
|
|
||||||
|
你可以在Feednix界面中来为你的Feedly账户增加任何一种RSS新闻源。要这么做,仅仅只需要按下"a"键,它会在屏幕底部显示一个"[ENTER FEED]:"的提示。在输入完RSS新闻源后,继续输入新闻源的名字和及其首选分类。
|
||||||
|
|
||||||
|
![](https://farm8.staticflickr.com/7324/16421639296_b52ed3c52e_c.jpg)
|
||||||
|
|
||||||
|
#### 总结 ####
|
||||||
|
|
||||||
|
如你所见, Feednix 是一个非常方便易用的命令行RSS阅读器。如果你是重度依赖命令行的用户,同时也是一个Feedly用户的话,Feednix 是肯定值得去尝试的。我和Feednix的开发者Jarkore交流解决了一些问题。我想说,对于[bug的报告][4]和修复他非常的积极。鼓励大家来试用Feednix,并且给他(Jarkore)一些回馈。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://xmodulo.com/feedly-rss-feed-command-line-linux.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[chenzhijun](https://github.com/chenzhijun)
|
||||||
|
校对:[wxy](https://github.com/wxy)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://xmodulo.com/author/nanni
|
||||||
|
[1]:https://feedly.com/
|
||||||
|
[2]:https://github.com/Jarkore/Feednix
|
||||||
|
[3]:https://aur.archlinux.org/packages/feednix/
|
||||||
|
[4]:https://github.com/Jarkore/Feednix/issues
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user