Revamped readme

This commit is contained in:
Matthew Holt 2016-06-21 11:28:38 -06:00
parent d9b6563d88
commit e585a74115
No known key found for this signature in database
GPG key ID: 0D97CC73664F4D03
2 changed files with 85 additions and 99 deletions

178
README.md
View file

@ -1,153 +1,137 @@
[![Caddy](https://caddyserver.com/resources/images/caddy-boxed.png)](https://caddyserver.com) <a href="https://caddyserver.com"><img src="https://caddyserver.com/resources/images/caddy-lower.png" alt="Caddy" width="350"></a>
[![community](https://img.shields.io/badge/community-forum-ff69b4.svg?style=flat-square)](https://forum.caddyserver.com) [![community](https://img.shields.io/badge/community-forum-ff69b4.svg?style=flat-square)](https://forum.caddyserver.com) [![twitter](https://img.shields.io/badge/twitter-@caddyserver-55acee.svg?style=flat-square)](https://twitter.com/caddyserver) [![Documentation](https://img.shields.io/badge/godoc-reference-blue.svg?style=flat-square)](https://godoc.org/github.com/mholt/caddy) [![Linux Build Status](https://img.shields.io/travis/mholt/caddy.svg?style=flat-square&label=linux+build)](https://travis-ci.org/mholt/caddy) [![Windows Build Status](https://img.shields.io/appveyor/ci/mholt/caddy.svg?style=flat-square&label=windows+build)](https://ci.appveyor.com/project/mholt/caddy)
[![Documentation](https://img.shields.io/badge/godoc-reference-blue.svg?style=flat-square)](https://godoc.org/github.com/mholt/caddy)
[![Linux Build Status](https://img.shields.io/travis/mholt/caddy.svg?style=flat-square&label=linux+build)](https://travis-ci.org/mholt/caddy)
[![Windows Build Status](https://img.shields.io/appveyor/ci/mholt/caddy.svg?style=flat-square&label=windows+build)](https://ci.appveyor.com/project/mholt/caddy)
Caddy is a lightweight, general-purpose web server for Windows, Mac, Linux, BSD Caddy is a general-purpose web server for Windows, Mac, Linux, BSD, and
and [Android](https://github.com/mholt/caddy/wiki/Running-Caddy-on-Android). [Android](https://github.com/mholt/caddy/wiki/Running-Caddy-on-Android). It is
It is a capable alternative to other popular and easy to use web servers. a capable but easier aternative to other popular web servers.
([@caddyserver](https://twitter.com/caddyserver) on Twitter)
The most notable features are HTTP/2, [Let's Encrypt](https://letsencrypt.org) [Releases](https://github.com/mholt/caddy/releases) ·
support, Virtual Hosts, TLS + SNI, and easy configuration with a [User Guide](https://caddyserver.com/docs) ·
[Caddyfile](https://caddyserver.com/docs/caddyfile). In development, you usually [Community](https://forum.caddyserver.com)
put one Caddyfile with each site. In production, Caddy serves HTTPS by default
and manages all cryptographic assets for you.
[Download](https://github.com/mholt/caddy/releases) ·
[User Guide](https://caddyserver.com/docs)
## Menu
### Menu - [Features](#features)
- [Getting Caddy](#getting-caddy)
- [Quick Start](#quick-start) - [Quick Start](#quick-start)
- [Running from Source](#running-from-source) - [Running from Source](#running-from-source)
- [Running in Production](#running-in-production)
- [Contributing](#contributing) - [Contributing](#contributing)
- [About the Project](#about-the-project) - [About the Project](#about-the-project)
## Features
## Getting Caddy - **Easy configuration** with Caddyfile
- **Automatic HTTPS** via [Let's Encrypt](https://letsencrypt.org); Caddy
Caddy binaries have no dependencies and are available for nearly every platform. obtains and manages all cryptographic assets for you
- **HTTP/2** enabled by default (powered by Go standard library)
[Latest release](https://github.com/mholt/caddy/releases/latest) - **Virtual hosting** for hundreds of sites per server instance, including TLS
SNI
- Experimental **QUIC support** for those that like speed
- TLS session ticket **key rotation** for more secure connections
- **Brilliant extensibility** so Caddy can be customized for your needs
- **Runs anywhere** with **no external dependencies** (not even libc)
## Quick Start ## Quick Start
The website has [full documentation](https://caddyserver.com/docs) but this will Caddy binaries have no dependencies and are available for every platform.
get you started in about 30 seconds: Install Caddy any one of these ways:
Place a file named "Caddyfile" with your site. Paste this into it and save: - [Download page](https://caddyserver.com/download) allows you to customize
your build in your browser
- [Latest release](https://github.com/mholt/caddy/releases/latest) for static
file downloads
- [curl getcaddy.com](https://getcaddy.com) for auto install:
`curl https://getcaddy.com | bash`
``` Once `caddy` is in your PATH, you can `cd` to your website's folder and run
`caddy` to serve it. By default, Caddy serves the current directory at
[localhost:2015](http://localhost:2015).
To customize how your site is served, create a file named Caddyfile by your
site and paste this into it:
```plain
localhost localhost
gzip gzip
browse browse
ext .html
websocket /echo cat websocket /echo cat
log ../access.log ext .html
log /var/log/access.log
proxy /api 127.0.0.1:7005
header /api Access-Control-Allow-Origin * header /api Access-Control-Allow-Origin *
``` ```
Run `caddy` from that directory, and it will automatically use that Caddyfile to When you run `caddy` in that directory, it will automatically find and use
configure itself. that Caddyfile to configure itself.
That simple file enables compression, allows directory browsing (for folders This simple file enables compression, allows directory browsing (for folders
without an index file), serves clean URLs, hosts a WebSocket echo server at without an index file), hosts a WebSocket echo server at /echo, serves clean
/echo, logs requests to access.log, and adds the coveted URLs, logs requests to access.log, proxies all API requests to a backend on
`Access-Control-Allow-Origin: *` header for all responses from some API. port 7005, and adds the coveted `Access-Control-Allow-Origin: *` header for
all responses from the API.
Wow! Caddy can do a lot with just a few lines. Wow! Caddy can do a lot with just a few lines.
To host multiple sites and do more with the Caddyfile, please see the
[Caddyfile documentation](https://caddyserver.com/docs/caddyfile).
#### Defining multiple sites Note that production sites (not localhost) are served over
[HTTPS by default](https://caddyserver.com/docs/automatic-https).
You can run multiple sites from the same Caddyfile, too: Caddy has a command line interface. Run `caddy -h` to view basic help or see
the [CLI documentation](https://caddyserver.com/docs/cli) for details.
```
site1.com {
# ...
}
site2.com, sub.site2.com {
# ...
}
```
Note that all these sites will automatically be served over HTTPS using Let's
Encrypt as the CA. Caddy will manage the certificates (including renewals) for
you. You don't even have to think about it.
For more documentation, please view [the website](https://caddyserver.com/docs).
You may also be interested in the [developer guide]
(https://github.com/mholt/caddy/wiki) on this project's GitHub wiki.
**Running as root:** We advise against this. You can still listen on ports
< 1024 using setcap like so: `sudo setcap cap_net_bind_service=+ep ./caddy`
## Running from Source ## Running from Source
Note: You will need **[Go 1.6](https://golang.org/dl/)** or newer (required for Note: You will need **[Go 1.6](https://golang.org/dl/)** or newer.
transparent automatic HTTP/2 support and to take advantage of performance improvements
in the TLS and crypto libraries).
1. `$ go get github.com/mholt/caddy/caddy` 1. `go get github.com/mholt/caddy`
2. `cd` into your website's directory 2. `cd` into your website's directory
3. Run `caddy` (assumes `$GOPATH/bin` is in your `$PATH`) 3. Run `caddy` (assumes `$GOPATH/bin` is in your `$PATH`)
If you're tinkering, you can also use `./build.bash && ./ecaddy`. Caddy's `main()` is in the caddy subfolder. To recompile Caddy, use
`build.bash` found in that folder.
By default, Caddy serves the current directory at
[localhost:2015](http://localhost:2015). You can place a Caddyfile to configure
Caddy for serving your site.
Caddy accepts some flags from the command line. Run `caddy -h` to view the help
for flags or see the [CLI documentation](https://caddyserver.com/docs/cli).
**Running as root:** We advise against this; use setcap instead, like so:
`setcap cap_net_bind_service=+ep ./caddy` This will allow you to listen on
ports < 1024 like 80 and 443.
#### Docker Container ## Running in Production
Caddy is available as a Docker container from any of these sources: The Caddy project does not officially maintain any system-specific
integrations, but your download file includes
- [abiosoft/caddy](https://hub.docker.com/r/abiosoft/caddy/) [unofficial resources](https://github.com/mholt/caddy/tree/master/dist/init)
- [darron/caddy](https://hub.docker.com/r/darron/caddy/) contributed by the community that you may find helpful for running Caddy in
- [joshix/caddy](https://hub.docker.com/r/joshix/caddy/) production.
- [jumanjiman/caddy](https://hub.docker.com/r/jumanjiman/caddy/)
- [zenithar/nano-caddy](https://hub.docker.com/r/zenithar/nano-caddy/)
- [zzrot/alpine-caddy](https://hub.docker.com/r/zzrot/alpine-caddy/)
#### 3rd-party dependencies
Although Caddy's binaries are completely static, Caddy relies on some excellent
libraries. [Godoc.org](https://godoc.org/github.com/mholt/caddy) shows the
packages that each Caddy package imports.
How you choose to run Caddy is up to you. Many users are satisfied with
`nohup caddy &`. Others use `screen`. Users who need Caddy to come back up
after reboots either do so in the script that caused the reboot, add a command
to an init script, or configure a service with their OS.
## Contributing ## Contributing
**[Join our community](https://forum.caddyserver.com) where you can chat with other Caddy users and developers!** **[Join our community](https://forum.caddyserver.com) where you can chat with
other Caddy users and developers!**
Please see our [contributing guidelines](https://github.com/mholt/caddy/blob/master/CONTRIBUTING.md). Please see our [contributing guidelines](https://github.com/mholt/caddy/blob/master/CONTRIBUTING.md)
and check out the [developer wiki](https://github.com/mholt/caddy/wiki).
We use GitHub issues and pull requests *only* for bug reports and discussing specific changes to Caddy. We welcome all other topics on the [forum](https://forum.caddyserver.com)! We use GitHub issues and pull requests only for discussing bug reports and
the development of specific changes. We welcome all other topics on the
[forum](https://forum.caddyserver.com)!
Thanks for making Caddy -- and the Web -- better! Thanks for making Caddy -- and the Web -- better!
@ -157,8 +141,7 @@ for hosting the Caddy project.
## About the Project
## About the project
Caddy was born out of the need for a "batteries-included" web server that runs Caddy was born out of the need for a "batteries-included" web server that runs
anywhere and doesn't have to take its configuration with it. Caddy took anywhere and doesn't have to take its configuration with it. Caddy took
@ -168,5 +151,8 @@ inspiration from [spark](https://github.com/rif/spark),
and [Vagrant](https://www.vagrantup.com/), and [Vagrant](https://www.vagrantup.com/),
which provides a pleasant mixture of features from each of them. which provides a pleasant mixture of features from each of them.
**The name "Caddy":** The name of the software is "Caddy", not "Caddy Server"
or "CaddyServer". Please call it "Caddy" or, if you wish to clarify, "the
Caddy web server". See [brand guidelines](https://caddyserver.com/brand).
*Twitter: [@mholt6](https://twitter.com/mholt6)* *Author on Twitter: [@mholt6](https://twitter.com/mholt6)*

6
dist/README.txt vendored
View file

@ -3,7 +3,7 @@ CADDY 0.9 beta 1
Website Website
https://caddyserver.com https://caddyserver.com
Community Forum Community
https://forum.caddyserver.com https://forum.caddyserver.com
Twitter Twitter
@ -18,7 +18,7 @@ For instructions on using Caddy, please see the user guide on
the website. For a list of what's new in this version, see the website. For a list of what's new in this version, see
CHANGES.txt. CHANGES.txt.
The Caddy project accepts pull requests! That means you can make The Caddy project accepts pull requests. That means you can make
changes to the code and submit it for review, and if it's good, changes to the code and submit it for review, and if it's good,
we'll use it! You can help thousands of Caddy users and level we'll use it! You can help thousands of Caddy users and level
up your Go programming game by contributing to Caddy's source. up your Go programming game by contributing to Caddy's source.
@ -36,4 +36,4 @@ And thanks - you're awesome!
--- ---
(c) 2015 - 2016 Matthew Holt (c) 2015-2016 Matthew Holt