PPA,或是Personal Package Archive(个人软件包存档),是默认情况下并未被包含在Ubuntu中的软件的一个集合。使用个人包存档(PPA),您可以直接向Ubuntu用户分发软件和更新。创建你的源码包,上传它,Launchpad将构建二进制文件,然后将它们托管在您自己的apt存储库中。 这意味着Ubuntu用户可以安装您的软件包,就像安装标准Ubuntu软件包一样,他们会自动接收更新。
Launchpad中的每个个人和团队都可以拥有一个或多个PPA,每个PPA都有自己的URL。 您在PPA中发布的软件包将保留在那里,直到您删除它们,它们将被您上传的另一个软件包或其所构建的Ubuntu版本所取代。
前期准备
而创建一个属于自己维护的PPA,大致包括一下流程:创建自己的GPG KEY密钥(用于对软件包认证和签名),SSH KEY,创建launchpad账户并配置密钥,安装打包环境,编写软件包,打包测试,对生成的软件包认证,最后上传到launchpad。下面我将逐步的介绍。
安装打包需要的软件环境
Ubuntu 11.10之前:
Ubuntu 11.10之后,可以通过如下命令安装:
创建自己的GPG key
1991年,程序员Phil Zimmermann为了避开政府监视,开发了加密软件PGP。这个软件非常好用,迅速流传开来,成了许多程序员的必备工具。但是,它是商业软件,不能自由使用。所以,自由软件基金会决定,开发一个PGP的替代品,取名为GnuPG。这就是GPG的由来。
如果想要将软件包上传到launchpad.net,就必须使用gpg签名。要配置gpg,可以参考gpp官网上的袖珍说明书。注意,过程中会要求你输入一个加密密码,一定要记住,不要乱写!!!
之后你应该会看到如下信息:
将key的公共部分上传到key server,这样全世界的开发者就可以根据你的key来识别你的信息和文件.
创建你的ssh key
ssh 代表安全的shell ,这里用来安全的把文件上传到PPA发布平台
创建pbuilder
pbuilder 是允许开发者在本地创建PPA包的工具.
之后便是漫长的等待…..
创建Launchpad账户
官网注册,之后上传GPG key到Launchpad。
例如我的:
登陆你的launchpad,选择下图红框的位置:
然后填写刚才我们查找的pub字段,密钥指纹中的字符串:
点击import 之后,系统会发送一封邮件到你的邮箱,用来对导入的key进行验证。你需要用自己的私钥对服务器用你刚上传公钥加密的内容进行解密 。其中邮件的内容为不可读的,需要解密的内容类似于:
将邮件中这些内容拷贝到一个文件中,例如:file.txt,然后执行如下命令:
此时会提示你输入之前设置的加密私钥key密码,解密成功后,会有如下提示:
复制该链接,在浏览器中打开,即完成了GPG key 上传。同样的方法,我们还要上传SSH KEY。
配置 Bazzar和环境变量
Bazzar一个版本控制软件同git一样,可以管理代码,Bazaar in five minutes 。这里我们安装一个bzr可视化管理工具,详见bzr explorer install.
告诉Bazzar你是谁,和git 中全局信息设置类似。
配置你的shell环境变量
打包上传
安装编译工具
这里我们使用openyoudao 软件包为例说明一个软件包的上传过程。首先下载Openyoudao源码包,Openyoudao代码托管在Github上,下载源码包,首先感谢 Linux之父林纳斯·托瓦兹发明了Git,为世界创造了一个知识传递平台.
根据模板生成配置文件
bzr-builddeb包括一个插件,用于从模板创建一个新的包。 插件是一个包装 dh_make命令,如果你安装了packaging-dev,你应该已经有了这些。 运行命令,提供上游tarball的软件包名称,版本号和路径。
之后你会看到,配置信息和本地软件包的编译位置。如 /home/pi/work/openyoudao
修改配置文件
这里我们主要修改openyoudao/debian/changelog 、control 两个文件。
- changelog文件中修改 trusty为ubuntu 14.04 的版本代号(代表我们的软件包运行平台)和版本号
- control 文件中修改 Section: net 不然会报错。
这里的配置信息很重要,不然你最后将软件包上传之后,可能会收到系统发送的拒绝邮件。你可能会遇到下面几个错误。
- 错误1解决方法:修改changelog文件中修改 将unstable 修改为ubuntu 对于平台版本代号 例如14.04 为trusty
- 错误2解决方法:修改control 文件中Section:unknown 为Section: net
- 错误3解决办法:
你上传的opencv_2.1.0.orig.tar.gz 已经存在于官方维护的存档中,你上传的版本与官方的冲突。更改版本号。
值得注意的是,这里大部分错误信息都可以在官方的文档中找到解决方法。参照打好的包: https://github.com/justzx2011/openyoudao/tree/beta
将修改提交到打包分支
之后你应该会看到如下信息:
在当前环境中编译软件包
附 debuild命令例子:
软件包生成完毕后,可以使用dpgk-deb来查看其内容清单。
检测软件包是否存在bug:
之后你应该会看到如下信息:
这里有几个错误信息,我们先略过,不影响下面的操作。
给软件包签名
这里我们用我们上传到launchpad中的GPG KEY 对我们的软件包进行签名。如果忘记自己的公钥代码,可以参加上面进行查询。
上传软件包
- 编辑~/.dput.cf
通过上面的一系列流程,我们生成了一组经过数字签名的文件,最后需要做的是将这些文件上传到ppa官方的ftp,此时会用到一个叫dput的软件,要使用dput,首先要编辑文件~/.dput.cf,没有就创建.在这个文件里面定义要上传的Launchpad账号。我的~/.dput.cf文件内容如下: - 执行上传
之后你应该会看到如下信息:
说明我们上传成功,这里你的邮箱会收到一封ppa发来的邮件,内容如下:
接下来就静待官方编译吧,编译进度可以在 Overview of published packages》View package details 中查看:
编译完成后,就可以通过ppa源进行安装了:
总结
创建launchpad账户》配置GPG密钥》配置ssh》创建project》编写软件包》创建本地编译环境》编译软件包》签名》上传 .changefile》等待官方确认邮件.
参考自http://web.archive.org/web/20160812065500/http://openyoudao.org:80/如何在ubuntu系统下制作自己的ppa安装包
- Packaging New Software
- Uploading a package to a PPA
- Package upload errors
- Bazaar Explorer install
- Build Debian packages from Bazaar branches
--------------------------
Ubuntu15.10系统下,制作自己的PPA安装包
Personal Package Archives(个人软件包档案)是Ubuntu Launchpad网站提供的一项服务,允许个人用户上传软件源代码,通过Launchpad进行编译并发布为2进制软件包,作为APT/新立得源供其他用户下载和更新。在Launchpad网站上的每一个用户和团队都可以拥有一个或多个PPA。
1.安装打包需要的软件环境:
$sudo apt-get install packaging-dev
2.创建自己的GPG KEY:
$gpg --gen-key
接下来,一路回车,在要求确认信息的时候,点击y。最后一步是一通的键盘乱按。整个过程如下图所示:
gpg: 正在检查信任度数据库
gpg: 需要 3 份勉强信任和 1 份完全信任,PGP 信任模型
gpg: 深度:0 有效性: 1 已签名: 0 信任度:0-,0q,0n,0m,0f,1u
pub 2048R/47EDFAD4 2016-01-23
密钥指纹 = 043D A507 281E D8F8 6D79 9806 34F5 C3F3 47ED FAD4
uid LongSky (LongSky) <wangqiang1588@sina.com>
sub 2048R/5A23BF98 2016-01-23
注意,我们需要的KEY ID为47EDFAD4.
将KEY的公共部分上传到KEY SERVER,这样全世界的开发者就可以根据你的KEY来识别你的信息和文件.
$gpg --send-keys --keyserver keyserver.ubuntu.com <KEY ID>
我们自己的Key发送就是:
$gpg --send-keys --keyserver keyserver.ubuntu.com 47EDFAD4
3.创建你的SSH KEY:
$ssh-keygen -t rsa
4.创建pbuilder(允许开发者在本地创建PPA包):
pbuilder-dist <release> create
where <release> is for example raring, saucy, trusty or in the case of Debian maybe sid.
This will take a while as it will download all the necessary packages for a “minimal installation”.
These will be cached though.
我的系统版本是Ubuntu 15.10 (Wily Werewolf),所以执行如下命令:
$pbuilder-dist wily create
这部分的耗时比较长,会安装全部的编译工具,要耐心等待一下!
5.创建Launchpad账户,
帐号可以去Launchpad 官网注册: https://login.launchpad.net/+new_account
上传GPG KEY到Launchpad,通过如下指令查看自己的GPG KEY:
$gpg --fingerprint wangqiang1588@sina.com
会得到如下结果:
pub 2048R/47EDFAD4 2016-01-23
密钥指纹 = 043D A507 281E D8F8 6D79 9806 34F5 C3F3 47ED FAD4
uid LongSky (LongSky) <wangqiang1588@sina.com>
sub 2048R/5A23BF98 2016-01-23
运行如下指令提交你的KEY到Ubuntu Key Server:
$gpg --send-keys --keyserver keyserver.ubuntu.com 47EDFAD4
登陆个人KEY管理面板: https://launchpad.net/~/+editpgpkeys
将Key fingerprint拷贝到文本框,点击 “Import Key”.
如果导入成功,系统会发送一封邮件到你的邮箱,用来对导入的Key进行验证
其中邮件的内容为不可读的,需要编译,内容类似于:
BEGIN PGP MESSAGE
Version: GnuPG v1.4.3 (GNU/Linux)
hQIOA0THhKozD+K5EAf9F3PcOL2iU6onH2YsvB6IKDXNxbK0NBVy6ppxcNq8hoTe
cuHvzWLFfh1ehhSNe1V6xpuFnt5sJoeA4qEEOxez3HmY80tKIKMPLyhC/8JiSIW9
fwuxj4C0F6pdyrpvGbQAzfPEFk/P1AtIHXm4WLXduhBT7YEpmUk/I4A/KlSrKoiP
J5vBtbroUyp2jvIhDUmY7ToU+ifrDe3+VP1ZzSEJzOOXec9oPbcbvf5NptXA7Hbp
S0ElBAcLjKpAu7VKotCwFZIsVXDHT/mxf2qm88bGIrlXS5uTzvmyhQps1KmyNiCz
I0i5kSVvHZWyVZ+8FrROLqYAqqnEIMg9hUnbFAervgf/YiYs0xxWLYf9e14eoMZA
ranGT72q/JHmBNBYenOijaquFNi1TH5J8Udtt2RfdyRUlmGilxRvtIYL8gpnuNpS
+GHOoBWUN2f4nawaDeqgrf6Nt3qQWWLO4iJPgieejFP2FP6zkLme1t7dXo+z1ary
EZuxSLtKIWkOFEZ8Gcn02hBgOhJZucnkF6BmVW9dr1C4QEAmGM631uqfsp5PapAn
yjHbEU1L2R9i7vPtJNRr6ubFLWg1Yhfv63ByxSx/WQHMMqlrbL+moXBGED3L2hM8
7FP9eapBRgmS+Bda9ArcGMUElTOkWoUYIOPyLOYmo15LvbxHOVaXjn7+fDgr2S1J
R9LArwHycmdKKelRww+ZvylHIfq8xy10atRQIYawchh9A1myXD1TlWbrrIkodQJF
iEpO2i1LKvqwZHOx3szT4hF+44tNFzQIL1j+zF5Hrt2WOTnS5WXGgGRtfEd8F7fN
khQZOAdhwrnlY+yknruC8Y8Jm8vM57+KnPgBfvxuxzLX1XFTfTZCHXeUmwwu3mga
m+6WzckeBGBDHKK6GqwFoOAykTwjyqOZaty7DPHeoINc0tLMVr9Ks64DScf8bgh4
MkNonA0YhMQbkmwRc33APw441+/iLw5gqndQdX44kKqC71dG6LqanAOjD29Xj3JV
ZBsjg95Jrx7Sx+i/V0PUeaU9QjCT0Q1jEy1Bcs8NYtTJnpG+4oHYJ0pyiGxIquQH
V9E+hW6Qehx5DbsIXEvfeaBBHOfAHHOhUH14WK4bsJWm8wZ50XiYBZrNFOqzsm13
2STcY4VIoJp3Uw2qNyvZXQUhpndlfgQGO14CMSadzDn6Vts=
=hTe6
END PGP MESSAGE
将邮件中这些内容拷贝到一个文件中,例如:file.txt,然后执行如下命令:
gpg --decrypt file.txt
此时会提示你输入之前设置的key密码,验证成功后,会有如下提示:
Please go here to finish adding the key to your Launchpad account:
[[https://launchpad.net/token/bP56TDKg8HXQbBs6LsN0]]
点击该链接,选择continue , 完成GPG Key 上传.
6.上传SSH KEY,
打开~/.ssh/id_rsa.pub文件,将其中的内容拷贝到帐号的add ssh key文本框中,选择导入后完成上传.
7.配置 Bazzar
(一个版本控制软件,可以储存代码)之所以需要使用Bazzar,原因是Launchpad的默认BUG管理器,并且编译代码的时候,要求用bzr进行代码编译。
首先告诉Bazzar你是谁:
$bzr whoami "LongSky <wangqiang1588@sina.com>"
$bzr launchpad-login wangqiang1588(我的Launchpad账户id)
Bazaar in five minutes: http://doc.bazaar.canonical.com/latest/en/mini-tutorial/
官方教程:http://packaging.ubuntu.com/html/packaging-new-software.html
开源许可证:http://opensource.org/licenses
8.配置你的shell环境变量:
打开~/.bashrc 文件,在文件开头加上如下内容:
$export DEBFULLNAME="LongSky"
$export DEBEMAIL="wangqiang1588@sina.com"
然后执行:
$source ~/.bashrc
9.安装编译工具
$sudo apt-get install build-essential dh-make
10.下载源代码,以Openyoudao为例:
$wget https://github.com/justzx2011/openyoudao/archive/beta0.2.tar.gz
11.开始打包
a.根据模板生成配置文件:
$bzr dh-make openyoudao 0.2 beta0.2.tar.gz
Fetching tarball
Looking for a way to retrieve the upstream tarball
Upstream tarball already exists in build directory, using that
Type of package: single binary, indep binary, multiple binary, library, kernel module, kernel patch?
[s/i/m/l/k/n] s
Maintainer name : LongSky
Email-Address : wangqiang1588@sina.com
Date : Sun, 24 Jan 2016 17:09:27 +0800
Package Name : openyoudao
Version : 0.2
License : blank
Type of Package : Single
Hit <enter> to confirm:
Skipping creating ../openyoudao_0.2.orig.tar.gz because it already exists
Currently there is no top level Makefile. This may require additional tuning.
Done. Please edit the files in the debian/ subdirectory now. You should also
check that the openyoudao Makefiles install into $DESTDIR and not in / .
Package prepared in /home/longsky/openyoudao
b.将修改提交到打包分支
$cd /home/longsky/openyoudao
$bzr commit -m "Initial commit of Debian packaging."
c.在当前环境中编译软件包
$bzr builddeb -- -us -uc
d.检测软件包是否存在BUG
$cd ..
$lintian openyoudao_0.2-1.dsc
e.给软件包签名(需要输入之前设置的密码)
$cd /home/longsky/openyoudao
$debuild -S -k47EDFAD4
12.上传软件包
a.编辑~/.dput.cf
通过上面的一系列流程,我们生成了一组经过数字签名的文件,最后需要做的是将这些文件上传到PPA官方的FTP,此时会用到一个叫dput的软件,要使用dput,首先要编辑文件~/.dput.cf,没有就创建.在这个文件里面定义要上传的Launchpad账号。我的~/.dput.cf文件内容如下:
[youdao-beta0.2]
fqdn = ppa.launchpad.net
method = ftp
incoming = ~wangqiang1588/openyoudao-v0.2/ubuntu/
login = anonymous
allow_unsigned_uploads = 0
b.执行上传:
$dput my-ppa openyoudao_0.2-1ubuntu1_source.changes
上传成功后会收到一封PPA发来的邮件,内容如下:
Accepted:
OK: openyoudao_0.2.orig.tar.gz
OK: openyoudao_0.2-1ubuntu1.debian.tar.gz
OK: openyoudao_0.2-1ubuntu1.dsc
-> Component: main Section: net
openyoudao (0.2-1ubuntu1) trusty; urgency=low
* fix issue#8, exception interrupt
https://launchpad.net/~wangqiang1588/+archive/openyoudao-v0.2
You are receiving this email because you are the uploader of the above
PPA package.
接下来就静待官方编译吧~
编译完成后,就可以通过ppa源进行安装了
编译进度可查看:http://ppa.launchpad.net/wangqiang1588/
--------------
--------------
ubuntu ppa的使用方法
看过我其他博客文章的童鞋应该知道,我最喜欢的发行版是Debian,不过最近换了VPS,暂时没有最近版的Debian,话说Debian 6上的默认Python版本还是2.6,不想自己折腾装2.7了,干脆用Ubuntu吧,他们提供了12.04LTS,默认Python是2.7了,不过Redis什么的版本还是太旧了,Ubuntu下有没有Debian那样方便好用的Dotdeb呢? 经过一番研究,发现了PPA这个东西,这个词到是经常看到,但是一直不太了解是什么,
PPA,或是Personal Package Archive(个人软件包存档),是默认情况下并未被包含在Ubuntu中的软件的一个集合。通常这些存储库的侧重点是单个的程序,不过他们也可以包含更多内容,这取决于这些存储库的维护者。一个PPA有可能关注的是一个未发布的软件,比如说Hotot,现有最好的Linux Twitter客户端。其也可能是包含了Ubuntu中已有的软件的更新,比如说Firefox。见什么是Ubuntu PPA以及为什么要用它[技术说明]
那它怎么用呢,简单:
- 安装PPA支持软件 apt-get install python-software-properties
- 到https://launchpad.net/ubuntu/+ppas搜索并找到你需要的软件源,以redis为例,找到了https://launchpad.net/~rwky/+archive/redis 这个,版本是最新的
- 添加到系统,并执行安装
sudo add-apt-repository ppa:rwky/redis
sudo apt-get update
sudo apt-get install redis
搞掂.
No comments:
Post a Comment