Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

0.23.0 #1459

Merged
merged 1 commit into from
Sep 6, 2024
Merged

0.23.0 #1459

Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,11 @@

- Put your changes here...

## 0.23.0

- Removed `cores` feature since it is largely redundant now thanks to the widespread popularity of tools like pm2. Also removed various deprecated cluster module support as well.
- Updated various dependencies.

## 0.22.16

- Made it possible to disable `helmet` by setting the `helmet` param to false.
Expand Down
1 change: 1 addition & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ If you are a maintainer of Roosevelt, please follow the following release proced

- Merge all desired pull requests into master.
- Bump `package.json` to a new version and run `npm i` to generate a new `package-lock.json`.
- If releasing a new major version, update the link to the previous versions of the documentation.
- Alter CHANGELOG "Next version" section and stamp it with the new version.
- Paste contents of CHANGELOG into new version commit.
- Open and merge a pull request with those changes.
Expand Down
33 changes: 2 additions & 31 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ Some notable features:
- [Available command line arguments](https://github.com/rooseveltframework/roosevelt#available-command-line-arguments)
- [Combining npm scripts and command line arguments](https://github.com/rooseveltframework/roosevelt#combining-npm-scripts-and-command-line-arguments)
- [Recognized environment variables](https://github.com/rooseveltframework/roosevelt#recognized-environment-variables)
- [Overriding recognized command line flags and environment variables](https://github.com/rooseveltframework/roosevelt#overriding-recognized-command-line-flags-and-environment-variables)
- [Default directory structure](https://github.com/rooseveltframework/roosevelt#default-directory-structure)
- [Configure your app with parameters](https://github.com/rooseveltframework/roosevelt#configure-your-app-with-parameters)
- [MVC parameters](https://github.com/rooseveltframework/roosevelt#mvc-parameters)
Expand Down Expand Up @@ -199,11 +198,6 @@ Roosevelt apps created with the app generator come with the following notable [n
- Default shorthands:
- `--prodproxy`
- `-x`
- `node app.js --cores n`: Configures how many CPUs your app will run on.
- `n` can be either a number representing the desired cores, or you can supply `max` to use all available CPUs.
- Default is `1`.
- Default shorthand:
- `-c`
- `node app.js --enable-validator`: Forces the HTML validator to be enabled.
- Default shorthands:
- `--html-validator`
Expand Down Expand Up @@ -236,22 +230,6 @@ Environment variable precedence:
- Environment variables supersede your app's [parameters](https://github.com/rooseveltframework/roosevelt#configure-your-app-with-parameters).
- Environment variables can be overridden with [command line arguments](https://github.com/rooseveltframework/roosevelt#available-command-line-arguments).

### Overriding recognized command line flags and environment variables

You can override the default command line flags and environment variables by providing a schema from [source-configs](https://github.com/rooseveltframework/source-configs) with a `"rooseveltConfig"` section. For instance, to set the number of cores from the command line with `"--num-cores"` or `"-n"` instead of the default `"--cores"` or `"-c"`, you could write:
```javascript
const schemaOverride = {
rooseveltConfig: { // we are overriding the Roosevelt config
cores: { // we are overriding the cores param in the Roosevelt config
commandLineArg: ['--num-cores', '-n'], // the new command line arg
envVar: ['NUM_CORES'] // a new environment variable to listen for
}
}
}
const params = {} // set any Roosevelt parameters here
require('roosevelt')(params, schemaOverride).startServer()
```

## Default directory structure

Below is the default directory structure for an app created using the Roosevelt app generator:
Expand Down Expand Up @@ -411,12 +389,6 @@ Resolves to:

### Deployment parameters

- `cores`: By default, Roosevelt will run on 1 CPU, but you can change the number of cores that the app will run on with this parameter.

- Default: *[Number]* `1`.

- To use all available cores, set this value to `max`.

- `hostPublic`: Whether or not to allow Roosevelt to host the public folder. By default in `production-proxy` mode Roosevelt will not expose the public folder. It's recommended instead that you host the public folder through another web server, such as Apache or nginx that is better optimized for hosting static files.

- Default: *[Boolean]* `false`.
Expand Down Expand Up @@ -1407,16 +1379,14 @@ Roosevelt's default session store for `express-session` works great if your app

#### Run the app behind a reverse proxy and use all the CPU cores

To do this, use the `production-proxy-mode` command line flag and the `cores` command line flag, e.g. `node app.js --production-proxy-mode --cores max`.
To do this, use the `production-proxy-mode` command line flag and run the process on multiple cores using a tool like [pm2](https://pm2.io/docs/runtime/guide/load-balancing/).

Then host your app behind a reverse proxy from a web server like Apache or nginx, which [is considered a best practice for Node.js deployments](https://expressjs.com/en/advanced/best-practice-performance.html#use-a-reverse-proxy).

Running the app in production-proxy mode runs the app in production mode, but with `localhostOnly` set to true and `hostPublic` set to false. This mode will make it so your app only listens to requests coming from the proxy server and does not serve anything in the public folder.

You will then need to serve the contents of the public folder directly via Apache or nginx.

https://github.com/rooseveltframework/roosevelt-sample-app

## Upgrading to new versions of Roosevelt

When you upgrade to a new version of Roosevelt, your Roosevelt config, npm run scripts, or other ways you use Roosevelt may need to be updated to account for breaking changes. There is a config auditor built-in to Roosevelt to detect most such issues, but not everything you might need to change is automatically detected.
Expand All @@ -1425,6 +1395,7 @@ Aside from the config auditor, one of the easiest ways to see what you might nee

### Documentation for previous versions of Roosevelt

- *[0.22.x](https://github.com/rooseveltframework/roosevelt/blob/e76256d82ef587d31320bcd52930a5358f9f2953/README.md)*
- *[0.21.x](https://github.com/rooseveltframework/roosevelt/blob/539e11dc9ce5f4d6340762dedb1a11134fe51b04/README.md)*
- *[0.20.x](https://github.com/rooseveltframework/roosevelt/blob/430a9bf8d193b177527872602b23ef3df08a9afa/README.md)*
- *[0.19.x](https://github.com/rooseveltframework/roosevelt/blob/aa10ea86f986f624bef56aa2f02ade5b6c551e13/README.md)*
Expand Down
1 change: 0 additions & 1 deletion lib/defaults/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,6 @@
"httpsPort": 9857,
"verbose": false
},
"cores": 1,
"shutdownTimeout": 30000,
"https": {
"enable": false,
Expand Down
3 changes: 0 additions & 3 deletions lib/scripts/configAuditor.js
Original file line number Diff line number Diff line change
Expand Up @@ -155,9 +155,6 @@ function configAudit (appDir) {
case 'controllersPath':
checkTypes(userParam, key, ['string'])
break
case 'cores':
checkTypes(userParam, key, ['number', 'string'])
break
case 'enableCLIFlags':
checkTypes(userParam, key, ['boolean'])
break
Expand Down
4 changes: 0 additions & 4 deletions lib/sourceParams.js
Original file line number Diff line number Diff line change
Expand Up @@ -197,10 +197,6 @@ module.exports = (params, app, appSchema) => {
default: defaults.frontendReload.verbose
}
},
cores: {
commandLineArg: ['--cores', '-c'],
default: defaults.cores
},
shutdownTimeout: {
default: defaults.shutdownTimeout
},
Expand Down
Loading
Loading