Browse Source

Merge pull request #228 from isocolsky/readme

Add installation guide to readme
activeAddress
Matias Alejo Garcia 10 years ago
parent
commit
ef64b1e031
  1. 8
      README.md
  2. 100
      installation.md

8
README.md

@ -27,13 +27,7 @@ More about BWS at http://blog.bitpay.com/2015/03/05/bitcore-wallet.html
BWS needs mongoDB. You can configure the connection at `config.js` BWS needs mongoDB. You can configure the connection at `config.js`
BWS supports SSL and Clustering. To configure them see [config.js](https://github.com/bitpay/bitcore-wallet-service/blob/master/config.js). BWS supports SSL and Clustering. For a detailed guide on installing BWS with extra features see [Installing BWS](https://github.com/bitpay/bitcore-wallet-service/blob/master/installation.md).
To use clustering, an external DB server and Lock server need to be configured. The lock server can be started `locker/locker.js`.
# Migration from LevelDB
Old versions of BWS uses LevelDB to store data. There is a migration script available at: `scripts/level2mongo.js`
# Security Considerations # Security Considerations

100
installation.md

@ -0,0 +1,100 @@
The following document is a step-by-step guide to run BWS in cluster mode.
Configuration for all required modules can be specified in https://github.com/bitpay/bitcore-wallet-service/blob/master/config.js
###Install BWS
```bash
npm install bws
cd bws
````
###Start MongoDB
Example configuration for connecting to the MongoDB instance:
```javascript
storageOpts: {
mongoDb: {
uri: 'mongodb://localhost:27017/bws',
},
}
```
###Start locker service
```bash
node locker/locker.js
````
Example configuration for connecting to locker service:
```javascript
lockOpts: {
lockerServer: {
host: 'localhost',
port: 3231,
},
}
```
###Start message broker service
```bash
node messagebroker/messagebroker.js
````
Example configuration for connecting to message broker service:
```javascript
messageBrokerOpts: {
messageBrokerServer: {
url: 'http://localhost:3380',
},
}
```
###Configure blockchain service
Note: this service will be used by blockchain monitor service as well as by BWS itself.
An example of this configuration is:
```javascript
blockchainExplorerOpts: {
livenet: {
provider: 'insight',
url: 'https://insight.bitpay.com:443',
},
testnet: {
provider: 'insight',
url: 'https://test-insight.bitpay.com:443',
},
}
```
###Start blockchain monitor service
The monitor service is used to notify instances of BWS of incoming txs. It will connect to all previous services so it is important that those are already running.
```bash
node bcmonitor/bcmonitor.js
````
###Start email service
```bash
node emailservice/emailservice.js
````
Example configuration for connecting to email service (using postfix):
```javascript
emailOpts: {
host: 'localhost',
port: 25,
ignoreTLS: true,
subjectPrefix: '[Wallet Service]',
from: 'wallet-service@bitcore.io',
}
```
###Enable clustering
Change `config.js` file to enable and configure clustering:
```javascript
{
cluster: true,
clusterInstances: 4,
}
```
###Start bws instances
```bash
npm start
````
Loading…
Cancel
Save