基于 Dropbear & Zlib 搭建轻量级的ssh server
【目的】
移植dropbear & zlib 在AM335X开发板上搭建轻量级的ssh server
【环境】
1、 Ubuntu 16.04发行版
2、 MC183平台
3、 交叉编译器arm-linux-gnueabihf-gcc-4.7.3
【步骤】
1、下载zlib-1.2.8.tar.gz dropbear-2015.67.tar.bz2源码。
2. 交叉编译zlib。
解压zlib-1.2.8.tar.gz
tar zvxf zlib-1.2.8.tar.gz
cd zlib-1.2.8
配置:
./configure --prefix=../../zlib/install
修该Makefile用于交叉编译,如下加粗字体为改动部分:
change Makefile
CROSS=arm-linux-gnueabihf-
CC=$(CROSS)gcc
CFLAGS=-O3 -D_LARGEFILE64_SOURCE=1 -DHAVE_HIDDEN
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
#CFLAGS=-g -DDEBUG
#CFLAGS=-O3 -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
# -Wstrict-prototypes -Wmissing-prototypes
SFLAGS=-O3 -fPIC -D_LARGEFILE64_SOURCE=1 -DHAVE_HIDDEN
LDFLAGS=
TEST_LDFLAGS=-L. libz.a
LDSHARED=$(CC) -shared -Wl,-soname,libz.so.1,--version-script,zlib.map
CPP=$(CC) -E
STATICLIB=libz.a
SHAREDLIB=libz.so
SHAREDLIBV=libz.so.1.2.8
SHAREDLIBM=libz.so.1
LIBS=$(STATICLIB) $(SHAREDLIBV)
AR=$(CROSS)ar
ARFLAGS=rc
RANLIB=$(CROSS)ranlib
LDCONFIG=ldconfig
LDSHAREDLIBC=-lc
TAR=tar
SHELL=/bin/sh
EXE=
#prefix =/usr/local
prefix=../../zlib/install
编译:
make
安装到prefix目录当中:
make install
用tree 显示安装目录如下所示:
install
├── include
│ ├── zconf.h
│ └── zlib.h
├── lib
│ ├── libz.a
│ ├── libz.so -> libz.so.1.2.8
│ ├── libz.so.1 -> libz.so.1.2.8
│ ├── libz.so.1.2.8
│ └── pkgconfig
│ └── zlib.pc
└── share
└── man
└── man3
└── zlib.3
3. 交叉编译dropbear。
解压dropbear-2015.67.tar.bz2
tar jvxf dropbear-2015.67.tar.bz2
cd dropbear-2015.67
配置:
./configure --prefix=../../dropbear/install --with-zlib=../../zlib/install/ CC=arm-linux-gnueabihf-gcc --host=arm-linux
会报如下错误:
configure: error: expected an absolute directory name for --prefix: ../../dropbear/install
因为—prefix需要一个绝对的路径,所以修该成如下进行配置
./configure --prefix=/home/vmuser/sdc/remote_svn/iotx-am335x/MC-183/package/dropbear/install --with-zlib=../../zlib/install/ CC=arm-linux-gnueabihf-gcc --host=arm-linux
默认编译安装:
default compile:
make
make install
自定义编译安装:
counster compile:
make PROGRAMS="dropbear dbclient dropbearkey dropbearconvert scp"
make PROGRAMS="dropbear dbclient dropbearkey dropbearconvert scp" install
用tree 显示安装目录如下所示:
install/
├── bin
│ ├── dbclient
│ ├── dropbearconvert
│ ├── dropbearkey
│ └── scp
├── sbin
│ └── dropbear
└── share
└── man
├── man1
│ ├── dbclient.1
│ ├── dropbearconvert.1
│ └── dropbearkey.1
└── man8
└── dropbear.8
4. 测试:
# download dbclient
wget http://192.168.3.88/dropbear/install/bin/dbclient -O /bin/dbclient && chmod +x /bin/dbclient
# download scp
wget http://192.168.3.88/dropbear/install/bin/scp -O /bin/scp && chmod +x /bin/scp
# download dropbearkey
wget http://192.168.3.88/dropbear/install/bin/dropbearkey -O /bin/dropbearkey && chmod +x /bin/dropbearkey
# download dropbearconvert
wget http://192.168.3.88/dropbear/install/bin/dropbearconvert -O /bin/dropbearconvert && chmod +x /bin/dropbearconvert
# download dropbear
wget http://192.168.3.88/dropbear/install/sbin/dropbear -O /bin/dropbear && chmod +x /bin/dropbear
# download libz so
wget http://192.168.3.88/zlib/install/lib/libz.so.1.2.8 -O /lib/libz.so.1.2.8 && chmod +x /lib/libz.so.1.2.8
# create soft ln
ln -s /lib/libz.so.1.2.8 /lib/libz.so
ln -s /lib/libz.so.1.2.8 /lib/libz.so.1
# mkdir /etc/dropbear
mkdir -p /etc/dropbear
cd /etc/dropbear
# generate dropbear_dss_host_key
root@am335x:/etc/dropbear# dropbearkey -t dss -f dropbear_dss_host_key
Generating key, this may take a while...
Public key portion is:
ssh-dss AAAAB3NzaC1kc3MAAACBAP3WPpjrRpLNaAZuABg4GYaHurc50gAmesgL/MFxj9aOfZ3n4GCmqD+fEfEkMok8KIdblyo7B/VX8ycM85EARMzQT7Y7t9KZRRIVTHNMG3NgalczaQOGYCdQs/QVNaMzKOCvt15rQQFdYNGmkoscNYROoKVau/16KJpC6QD70bAdAAAAFQDsjhDS8hI1Ilxo/t4UDl5q2VDnywAAAIEAjlslkIGvLQhxa1lm+3BL6PnXc9dIizfCMLtp+eS178fJdoLceLhC+FrTwVyaLAUrvElvqgkYkGtx/DtNmw3xyE2d6Fu4uFT1FuyPBJxxYAnJc6odKG64mZXSiPz5hkalcPmi/oDE4Y7TT6GwEorTQ5CyS7jZc/vgOOry5rG+gcUAAACBAP1Vvx4DsCVF0KEgx04j1sRzGp9MjkXd+S4sA1hOXUJ5VVmtqMYn5XBJTCfsNBCMsVAWAIP3usvHlLuXTD/nC23fUw2gPpBEBiCQCThbingyqT7wQ4ZQFlO8yHRr4peBxyUK2PFyVDPGohl5cSO+XaaWVUe33Cg/Rk5xl1Q4b5gbroot@am335x Fingerprint: md5 09:e2:6c:93:39:d0:08:1e:97:64:74:c8:d6:78:97:6e
# generate dropbear_rsa_host_key
root@am335x:/etc/dropbear# dropbearkey -t rsa -f dropbear_rsa_host_key
Generating key, this may take a while...
Public key portion is:
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC5txR31wx+AXiy4nOanuocphD7VYTQa5L1yLmANQVZnZh2itRnuMrsAfSBOkKIOo2UwcK9iyJCWXFmcoLe6acXIeX/mAP4OzgOqi1gLJoBw/y3vmeIzJJP1Qn96iVhZqL1NLjqj863+LNi20WuvYzdKbd13dbTGnE7auDynKLlE+LudSg2MjDLhJ7VZ4tGagoxY4HkRfGgKha2+K7CeCvby29St5QOt8HWjbOBM6MaNqX09GH7W1hpzti39xpZwz8YakPWMgYd6/elBFtVx0tZhg/80xq1HHG5OtDM6Fzo+wtZODb5r2gEBvYPJ+DaX06x9f6WOaWXtKnV5IEu3GF/ root@am335x
Fingerprint: md5 09:0c:bc:c0:c9:85:26:c1:aa:00:4a:0f:7e:23:33:1d
# restart dropbear
killall -9 dropbear
dropbear -p 22 &
基于 Dropbear & Zlib 搭建轻量级的ssh server的更多相关文章
- VMWare9下基于Ubuntu12.10搭建Hadoop-1.2.1集群
VMWare9下基于Ubuntu12.10搭建Hadoop-1.2.1集群 下一篇:VMWare9下基于Ubuntu12.10搭建Hadoop-1.2.1集群-整合Zookeeper和Hbase 近期 ...
- 【Nginx】如何基于主从模式搭建Nginx+Keepalived双机热备环境?这是最全的一篇了!!
写在前面 最近出版了<海量数据处理与大数据技术实战>,详情可以关注 冰河技术 微信公众号,查看<我的<海量数据处理与大数据技术实战>出版啦!>一文. 也有不少小伙伴 ...
- 基于 Hexo 从零开始搭建个人博客(二)
阅读本篇前,请先配置好相应的环境,请仔细阅读教程 基于 Hexo 从零开始搭建个人博客(一). 原文链接:基于 Hexo 从零开始搭建个人博客(二) 前言 博客搭建过程遇到任何问题,优先在本页面搜索, ...
- Ubuntu配置ssh server
SSH-Server配置指南 一.SSH简介 SSH (Secure Shell)是一个应用程序中提供安全通信的协议,通过SSH协议可以安全地访问服务器,因为SSH 具有成熟的公钥加密体系,在数据进行 ...
- Linux下设置SSH Server设置时间链接限制
OpenSSH基于安全的理由,如果用户连线到SSH Server后闲置一段时间,SSH Server会在超过特定时间后自动终止SSH连线.本人习惯长时间连接,需要做如下修改: 1.打开ssh配置文件: ...
- 基于VMware Workstation搭建开发服务器
基于VMware Workstation搭建开发服务器 文章为本人原创,转载请联系作者并注明出处.晓松 源URL: https://www.jianshu.com/p/e62ab7de0124 我 ...
- CentOS 环境下基于 Nginx uwsgi 搭建 Django 站点
因为我的个人网站 restran.net 已经启用,博客园的内容已经不再更新.请访问我的个人网站获取这篇文章的最新内容,CentOS 环境下基于 Nginx uwsgi 搭建 Django 站点 以下 ...
- Mac上基于hexo+GitHub搭建个人博客(一)
原文地址: http://fanjiajia.cn/2018/11/23/Mac%E4%B8%8A%E5%9F%BA%E4%BA%8Ehexo+GitHub%E6%90%AD%E5%BB%BA%E4% ...
- OpenMediaVault 搭建git,ssh无法连接问题
/************************************************************************* * OpenMediaVault 搭建git,ss ...
随机推荐
- 求文件的hash值(基于SHA3的Hash)
import hashlib import tkinter from tkinter import filedialog import pyperclip def fileHash(fileName) ...
- Android JNI 传递对象
JNI初步入门后,在传递数据的时候,遇到一个需求:有多个数据需要在Java与C代码之间进行传递.如果都做为函数参数传入,则函数很长很难看,并且多个数据的返回也不好实现.所以想到了把数据打包后传递.这在 ...
- Centos 7 Docker安装配置
版本介绍 Docker从1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE.社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比如经过官方测试认证过的基础设 ...
- Basic Calculator 基本计算器
2018-09-27 22:02:36 一.Basic Calculator II 问题描述: 问题求解: sign用来保存前一个符号,用num来记录数字,如果碰到一个符号或者到达结尾,则需要进行入栈 ...
- arcgis 浅入
首先声明,此文只是用于学习,非商业用途!!20181226谷子弟留 有朋友需要用arcgis来学习分析图块,实现图块的分类和数据分析和统计. 于是网上找了找资源. http://pan.baidu ...
- sql---->sql-summary&mysql-summary
数据库操作: 1.创建数据库,并修改默认字符编码 create database 数据库名 [charset=字符编码]; ee: create database dog charset=utf8; ...
- LeetCode--682--棒球比赛(java)
你现在是棒球比赛记录员. 给定一个字符串列表,每个字符串可以是以下四种类型之一:1.整数(一轮的得分):直接表示您在本轮中获得的积分数.2. "+"(一轮的得分):表示本轮获得的得 ...
- hdu-2709整数划分 技巧
整数划分变形,由2^k组成. 整数划分中一个节约内存的技巧,平时我们使用dp[i][j]维护用不大于j的数组合成i的方案数,所以必须dp[i-j][j]->dp[i][j].这样就需要二位,如果 ...
- Linux虚拟机安装VMware Tools
选择虚拟机-->install VMware Tools # 新建一个文件夹用来挂载光驱 mkdir /mnt/cdrom # 挂载光驱到指定文件夹 mount /dev/sr0 /mnt/cd ...
- mysql之filesort原理
在执行计划中,可能经常看到有Extra列有filesort,这就是使用了文件排序,这当然是不好的,应该优化,但是,了解一下他排序的原理也许很有帮助,下面看一下filesort的过程: 1.根据表的索引 ...