【目的】

移植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的更多相关文章

  1. VMWare9下基于Ubuntu12.10搭建Hadoop-1.2.1集群

    VMWare9下基于Ubuntu12.10搭建Hadoop-1.2.1集群 下一篇:VMWare9下基于Ubuntu12.10搭建Hadoop-1.2.1集群-整合Zookeeper和Hbase 近期 ...

  2. 【Nginx】如何基于主从模式搭建Nginx+Keepalived双机热备环境?这是最全的一篇了!!

    写在前面 最近出版了<海量数据处理与大数据技术实战>,详情可以关注 冰河技术 微信公众号,查看<我的<海量数据处理与大数据技术实战>出版啦!>一文. 也有不少小伙伴 ...

  3. 基于 Hexo 从零开始搭建个人博客(二)

    阅读本篇前,请先配置好相应的环境,请仔细阅读教程 基于 Hexo 从零开始搭建个人博客(一). 原文链接:基于 Hexo 从零开始搭建个人博客(二) 前言 博客搭建过程遇到任何问题,优先在本页面搜索, ...

  4. Ubuntu配置ssh server

    SSH-Server配置指南 一.SSH简介 SSH (Secure Shell)是一个应用程序中提供安全通信的协议,通过SSH协议可以安全地访问服务器,因为SSH 具有成熟的公钥加密体系,在数据进行 ...

  5. Linux下设置SSH Server设置时间链接限制

    OpenSSH基于安全的理由,如果用户连线到SSH Server后闲置一段时间,SSH Server会在超过特定时间后自动终止SSH连线.本人习惯长时间连接,需要做如下修改: 1.打开ssh配置文件: ...

  6. 基于VMware Workstation搭建开发服务器

    基于VMware Workstation搭建开发服务器   文章为本人原创,转载请联系作者并注明出处.晓松 源URL: https://www.jianshu.com/p/e62ab7de0124 我 ...

  7. CentOS 环境下基于 Nginx uwsgi 搭建 Django 站点

    因为我的个人网站 restran.net 已经启用,博客园的内容已经不再更新.请访问我的个人网站获取这篇文章的最新内容,CentOS 环境下基于 Nginx uwsgi 搭建 Django 站点 以下 ...

  8. 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% ...

  9. OpenMediaVault 搭建git,ssh无法连接问题

    /************************************************************************* * OpenMediaVault 搭建git,ss ...

随机推荐

  1. 求文件的hash值(基于SHA3的Hash)

    import hashlib import tkinter from tkinter import filedialog import pyperclip def fileHash(fileName) ...

  2. Android JNI 传递对象

    JNI初步入门后,在传递数据的时候,遇到一个需求:有多个数据需要在Java与C代码之间进行传递.如果都做为函数参数传入,则函数很长很难看,并且多个数据的返回也不好实现.所以想到了把数据打包后传递.这在 ...

  3. Centos 7 Docker安装配置

    版本介绍 Docker从1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE.社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比如经过官方测试认证过的基础设 ...

  4. Basic Calculator 基本计算器

    2018-09-27 22:02:36 一.Basic Calculator II 问题描述: 问题求解: sign用来保存前一个符号,用num来记录数字,如果碰到一个符号或者到达结尾,则需要进行入栈 ...

  5. arcgis 浅入

    首先声明,此文只是用于学习,非商业用途!!20181226谷子弟留   有朋友需要用arcgis来学习分析图块,实现图块的分类和数据分析和统计. 于是网上找了找资源. http://pan.baidu ...

  6. sql---->sql-summary&mysql-summary

    数据库操作: 1.创建数据库,并修改默认字符编码 create database 数据库名 [charset=字符编码]; ee: create database dog charset=utf8; ...

  7. LeetCode--682--棒球比赛(java)

    你现在是棒球比赛记录员. 给定一个字符串列表,每个字符串可以是以下四种类型之一:1.整数(一轮的得分):直接表示您在本轮中获得的积分数.2. "+"(一轮的得分):表示本轮获得的得 ...

  8. hdu-2709整数划分 技巧

    整数划分变形,由2^k组成. 整数划分中一个节约内存的技巧,平时我们使用dp[i][j]维护用不大于j的数组合成i的方案数,所以必须dp[i-j][j]->dp[i][j].这样就需要二位,如果 ...

  9. Linux虚拟机安装VMware Tools

    选择虚拟机-->install VMware Tools # 新建一个文件夹用来挂载光驱 mkdir /mnt/cdrom # 挂载光驱到指定文件夹 mount /dev/sr0 /mnt/cd ...

  10. mysql之filesort原理

    在执行计划中,可能经常看到有Extra列有filesort,这就是使用了文件排序,这当然是不好的,应该优化,但是,了解一下他排序的原理也许很有帮助,下面看一下filesort的过程: 1.根据表的索引 ...