基于 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 ...
随机推荐
- Windows下pipenv将虚环境文件的位置设置在项目根目录下
在windows下使用pipenv shell时,虚拟环境文件夹会在C:\Users\Administrator\.virtualenvs\目录下默认创建,为了方便管理,将这个虚环境的文件的位置更改一 ...
- leecode第一百四十二题(环形链表II)
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode ...
- ssh连接docker镜像ubuntu与debian
用密码登录root docker官网给的sshdemo是ubuntu的,https://docs.docker.com/engine/examples/running_ssh_service/ 亲 ...
- centos7在upgrade的时候显示:Delta RPMs disabled because /usr/bin/applydeltarpm not installed
前面安装信息,太多,省略 总计:113 MIs this ok [y/d/N]: yDownloading packages:Delta RPMs disabled because /usr/bin/ ...
- Wannafly挑战赛19 B矩阵
矩阵 思路: 预处理好前缀和,枚举上边界和下边界,将二维变成一维,用单调队列找满足题意的最小前缀 复杂度,O(r*r*c) 代码: #pragma GCC optimize(2) #pragma GC ...
- 用原生js来处理跨域的数据(jsonp)
说明总结: 1.ajax和jsonp其实本质上是不同的东西.ajax的核心是通过XmlHttpRequest获取非本页内容,而jsonp的核心则是动态添加<script>标签来调用服务器提 ...
- 第 2 章 容器架构 - 007 - Docker 架构详解
Docker 的核心组件包括: Docker 客户端 - Client Docker 服务器 - Docker daemon Docker 镜像 - Image Registry Docker 容器 ...
- 合并k个排序的列表 Merge k Sorted Lists
2018-11-25 22:58:52 问题描述: 问题求解: 本题可以使用优先队列高效的进行求解,整体的时间复杂度为O(nlogk). public ListNode mergeKLists(Lis ...
- Shell函数和数组
函数的返回值用return,脚本的返回值用exit shell函数只允许返回数字,若不是则报line 6: return: num: numeric argument required:若是写了ret ...
- 看到篇博文,用python pandas改写了下
看到篇博文,https://blog.csdn.net/young2415/article/details/82795688 需求是需要统计部门礼品数量,自己简单绘制了个表格,如下: 大意是,每个部门 ...