Giter Site home page Giter Site logo

clear-code / openresty-packaging Goto Github PK

View Code? Open in Web Editor NEW

This project forked from openresty/openresty-packaging

0.0 2.0 0.0 335 KB

Official OpenResty packaging source and scripts for various Linux distributions and other systems

Home Page: https://openresty.org/en/linux-packages.html

Shell 47.84% Makefile 34.98% Perl 17.18%

openresty-packaging's Introduction

Name

openresty-packaging - Official OpenResty packaging source and scripts for various Linux distributions.

Table of Contents

Description

This code repository holds the source for building the official OpenResty pre-built packages published below:

https://openresty.org/en/linux-packages.html

https://openresty.org/en/rpm-packages.html

https://openresty.org/en/deb-packages.html

If you just want to use these pre-built (binary) packages and the corresponding package repositories, then simply follow the instructions in these pages instead.

Otherwise, if you want to hack on or customize these packages yourself, for example, please read on.

Supported Systems

Fedora

For Fedora 22+:

# create the makerpm account for building rpms only:
sudo useradd makerpm
sudo usermod -a -G mock makerpm
sudo passwd makerpm

# install rpm build tools:
sudo dnf install @development-tools fedora-packager rpmdevtools

# install openresty's build requirements:
sudo dnf install openssl-devel zlib-devel pcre-devel gcc make perl perl-Data-Dumper

# login as makerpm:
sudo su - makerpm

cd ~
rpmdev-setuptree

cp /path/to/openresty-packaging/rpm/SOURCES/* ~/rpmbuild/SOURCES/

cd ~/rpmbuild/SPECS
cp /path/to/openresty-packaging/rpm/SPECS/*.spec ./

for file in *.spec; do
    spectool -g -R $file
    rpmbuild -ba $file
done

If success, binary rpm files are under ~/rpmbuild/RPMS/ while source rpm files are under ~/rpmbuld/SRPMS/.

See the How to create an RPM package wiki page for more details.

Back to TOC

CentOS/RHEL

For CentOS/RHEL 6+:

# create the makerpm account for building rpms only:
sudo useradd makerpm
sudo groupadd mock
sudo usermod -a -G mock makerpm
sudo passwd makerpm

# install rpm build tools:
sudo yum install rpm-build redhat-rpm-config rpmdevtools

# install openresty's build requirements:
sudo yum install openssl-devel zlib-devel pcre-devel gcc make perl \
    perl-Data-Dumper libtool ElectricFence systemtap-sdt-devel valgrind-devel

# login as makerpm:
sudo su - makerpm

mkdir -p ~/rpmbuild/{BUILD,RPMS,SOURCES,SPECS,SRPMS}
echo '%_topdir %(echo $HOME)/rpmbuild' > ~/.rpmmacros

cp /path/to/openresty-packaging/rpm/SOURCES/* ~/rpmbuild/SOURCES/

cd ~/rpmbuild/SPECS
cp /path/to/openresty-packaging/rpm/SPECS/*.spec ./

for file in *.spec; do
    spectool -g -R $file
    rpmbuild -ba $file
done

See this wiki page for more details.

Back to TOC

Amazon Linux

Similar to Fedora. Just make sure you have installed the following package to genreate those *-debuginfo packages automatically:

sudo yum install redhat-rpm-config

Back to TOC

Ubuntu/Debian

For Ubuntu 14.04+ and Debian 7.x+:

sudo apt-get install libtemplate-perl dh-systemd systemtap-sdt-dev perl gnupg curl make build-essential dh-make bzr-builddeb

cd /path/to/openresty-packaging/deb/
make zlib-build
make pcre-build
make openssl-build
make openssl-debug-build
make openresty-build
make openresty-debug-build
make openresty-valgrind-build
make lemplate-build
make test-nginx-build

Or to build everything from scratch, just run

make build

On Debian 7.x wheezy, you'll also need to enable the wheezy-backports apt source.

To generate degian source packages for uploading to Launchpad PPA servers, one can add the OPTS=-S argument, as in

make zlib-build OPTS=-S
make pcre-build OPTS=-S

It is also possible to generate debian source packages for any other Ubuntu or Debian codenames. For example:

make zlib-build DISTRO=trusty
make zlib-build OPTS=-S DISTRO=trusty

Back to TOC

Alpine

sudo apk add alpine-sdk

mkdir -p ~/.abuild
echo "JOBS="`nproc` >> ~/.abuild/abuild.conf

cd /path/to/openresty-packaging/alpine/

cd openresty-zlib
abuild -r
cd ..

cd openresty-pcre
abuild -r
cd ..

cd openresty-openssl
abuild -r
cd ..

cd openresty
abuild -r
cd ..

cd lemplate
abuild -r
cd ..

# and etc...

Author

Yichun Zhang (agentzh) <[email protected]>

Back to TOC

Copyright and License

This module is licensed under the BSD license.

Copyright (C) 2016-2017 by Yichun "agentzh" Zhang (章亦春) <[email protected]>, OpenResty Inc.

All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  • Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  • Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Back to TOC

See Also

Back to TOC

openresty-packaging's People

Contributors

agentzh avatar zhuizhuhaomeng avatar luto avatar happyaron avatar satchamo avatar nielsek avatar membphis avatar detailyang avatar doujiang24 avatar rainingmaster avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.