Skip to content

barbarahui/appstrap

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

appstrap

utilities to bootstrap your app stack

Consistent, reproducible computing environments. In a unix shell account of an unprivileged user.

Currently a hybrid of pkgsrc and ansible with bash and python

this project is under active development but is not yet used in production, and this checkout may not be stable

"role" account as per CDL standard operating procedure is a unix shell account.

To set up an application stack in a new or "distclean" role account, first checkout this repository:

cd
git clone https://github.com/ucldc/appstrap.git

Then; run one of scripts to set up your application stack:

  • ~/appstack/stack_dsc
  • ~/appstack/stack_nuxeo
  • ~/appstack/stack_registry
  • ~/appstack/stack_solr

See also https://github.com/ucldc/appstrap/wiki

pkgsrc where have you been all my life? So glad to finally find this from NetBSD -- it works on Linux too! I wrote a little wrapper for it so I can do one command installs of these NetBSD packages for my SUSE/Linux app stack.

Appstrap provides a wrapper around pkgsrc called pmake and some other utility scripts to set up web servers.

Install appstrap

Go to your home directory and check out this repository.

git clone https://github.com/tingletech/appstrap.git

add something like this to the end of your .bashrc

# .bashrc
if [ -e $HOME/appstrap/setenv.sh ]; then
  . $HOME/appstrap/setenv.sh
fi

This will install the utility tree

./appstrap/pmake sysutils/tree

For this shell, you will need to source ~/.bashrc and now tree should be on your path.

How to find a package and add it to your app stack

  1. Find your package in one of these lists.

  2. Find the directory name on the package README.html. Look for The package is located in the "xxx/yyy" directory. xxx/yyy will be a link

  3. Use the directory name as a command line parameter to pmake.

For example

./pmake devel/scmgit-base

will install pkgsrc if it is not already there; and then install git with all its dependencies into ~/pkg.

This will install ffmpeg and shibboleth

ACCEPTABLE_LICENSES=lame-license ./pmake multimedia/ffmpeg
./pmake www/shibboleth-sp

or, install many things at once

./pmake graphics/ImageMagick print/poppler-utils

Works on the SUSE VMs I can get from the datacenter.

Directory Structure

.
├── appstrap     # <= this repository (you are here)
├── certs        # put ssl certs and other credentials in this directory
├── pkg          # packages get installed in here
├── pkgsrc       # magic checked out from NetBSD CVS / downloaded source / built packages
└── servers      # local edits to pkg/etc files

Note: it is sort of slow the first time because it has to download and all the source and build all the packages, but I'm going to try to figure out how to set up a local repository of the packages so that I only have to build them once per each of -dev, -stg, and prod.

About pkgsrc

The NetBSD Packages Collection (pkgsrc) is a framework for building third-party software on NetBSD and other UNIX-like systems, currently containing over 13000 packages. It is used to enable freely available software to be configured and built easily on supported platforms.

It has stable branches that are tagged every quarter of the year, and the current (2013-05-30) release is their 50th.

role_test_certs

Create test certificates for use with ssl/https

shib_it

Shibboleth needs to be compiled with --prefix to run w/o root. Run this command to set up shibboleth.

./shib_it --prefix ${HOME}/servers/shibboleth --other-prefix {$HOME}/pkg --temp-dir ${HOME}/tmp

The --prefix is where stuff gets installed and --other-prefix is where the boost headers are installed. The --temp-dir is needed for machines with small root or tmp partitions because this downloads and compiles a lot of code.

jpache

Get ant, maven, and tomcat binary java packages from apache.

./jpache --prefix=${HOME}/java 

License

Copyright © 2013, Regents of the University of California 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.
  • Neither the name of the University of California nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

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 OWNER 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.

About

utilities to bootstrap your app stack

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 70.9%
  • Python 29.1%