Giter VIP home page Giter VIP logo

appbox-cookbook's Introduction

Chef cookbook - appbox (v0.1.1)

Provides a set of recipes to setup a base app server:

  • create users and groups
  • setup base directory to store apps
  • install common sysadmin tools

Install

To install with Berkshelf, add this into Berksfile:

cookbook 'appbox'

Usage

To setup a base app server,

Add appbox::default recipe into run list, or include the recipe in your code:

include_recipe "appbox::default"

And override attributes to customize the cookbook.

See also teohm/kitchen-sample for appbox usage example with chef-solo.

Attributes

You should set these attributes:

  • node["appbox"]["admin_keys"] (default: []) - a list of authorized SSH public keys for admin user.
  • node["appbox"]["deploy_keys"] (defaults: []) - a list of authorized SSH public keys for deploy user.

You may customize these attributes:

  • node["appbox"]["admin_user"] (default: "devops") - admin account, to perform sysadmin tasks (login with SSH key, passwordless sudo, member of apps group).
  • node["appbox"]["deploy_user"] (default: "deploy") - deploy account, to deploy apps (login with SSH key, passwordless sudo, member of apps group).
  • node["appbox"]["apps_user"] (default: "apps") - apps account, to run apps (no login, not sudoer, member of apps group).
  • node["appbox"]["apps_dir"] (default: "/home/apps") - base directory to store apps, writable (with +SGID) by apps group members.

Recipes

  • appbox::default - run all recipes.
  • appbox::package_update - update software packages (with apt-get update).
  • appbox::users - create users and groups.
  • appbox::apps_dir - setup base directory to store apps.
  • appbox::tools - install the following tools:
    • curl
    • htop
    • git
    • tmux

Requirements

Supported Platforms

  • ubuntu - tested on Ubuntu 12.10
  • debian - should work

Pull requests, issue and test reports are welcomed to better support your platform.

Cookbook Dependencies

  • Depends on these cookbooks:
    • apt
    • sudo
    • user
    • curl
    • htop
    • git
    • tmux

License and Authors

Copyright 2013, Huiming Teo

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

appbox-cookbook's People

Contributors

teohm avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

appbox-cookbook's Issues

Setup ssh-keypair for deployment

This might be out of scope, but I think that the job of this recipe is to get your application setup so that you are ready to do first time install of your app (for example cap deploy:setup). In order for this to possible, we need to have the right keys in place (deploy key for private repos).

I am thinking of using attributes to get the private and public keys and simply add those to the .ssh directory with the proper naming and permissions.

What do you think?

Add CentOS support

I've always been a fan of Ubuntu, but these days I need to work on CentOS. And I've come to find good things about it too (e.g. SELinux enabled by default).

Are you interested in having me work on the 3 cookbooks to add support for CentOS and soon Amazon Linux (also in the RedHad family)?

To be clear: I'm doing this. I just want to know if you want to keep your cookbooks Ubuntu-focused or if you're interested in me submitting pull request(s) :-)

Production log permission error of Passenger Standalone server

Got Production log permission error while running app under Passenger Standalone server via sv. Here is the line from log file:

Rails Error: Unable to access log file. Please ensure that /home/apps/app2/releases/20130511000523/log/production.log exists and is chmod 0666. The log level has been raised to WARN and the output directed to STDERR until the problem is fixed.

The permission of this log file is 0644 and the owner of this file is deploy:apps, which is different with others' apps:apps. I am wondering whether can change the permission of file to 0664 or change the user of the process writing log to apps.

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.