Organic Lawn Care Schedule

I have been attempting to perfect my organic lawn care schedule for the past three or so years. Here is my plan for 2017.  My lawn is 5000sq feet.

April:  Corn Gluten Meal for weed suppression, before the forsythias bloom. Temps should be about 60.  I’m going to use Safe’N Simple Pre-emergence Weed Control 9-0-0.  It sells for $50 for 50lbs.  Apply 20lbs per 1000sq feet. (Scotts SpeedyGreen 2000 setting: 16)
* Week 1: Lime/Sulfur:   Lime RAISES PH and Sulfur LOWERS PH.  A good indicator that you have high PH is dandelions.  If you have low PH, you should see a lot of clover.  I don’t mind the clover, but dandelions need to go. (Scotts SpeedyGreen 2000 setting: 5)
* Week 2: Fertilizer  (Scotts SpeedyGreen 2000 setting: 11.5)
* Week 3: Seed
* Grub Control – Milky Spore – (Scotts SpeedyGreen 2000 setting: 3)
* Grub Control – Milky Spore – (Scotts SpeedyGreen 2000 setting: 3)
* Fertilizer  (Scotts SpeedyGreen 2000 setting: 11.5)
* Grub Control – Milky Spore – (Scotts SpeedyGreen 2000 setting: 3)
* Fertilizer  (Scotts SpeedyGreen 2000 setting: 11.5)
* Seed
* Fertilizer  (Scotts SpeedyGreen 2000 setting: 11.5)

For fertilizer, I have been using Miloganite which can be found at Home Depot and they claim it’s organic.  As shown above, it’s applied four times a year.

For grub control, I’m trying milky spore.  Unfortunately I’m not 100% sure what type of grub I have so I don’t think it’s working that well.  I’m tempted to just use regular grub control, but afraid that it will nuke everything I’m trying to do.

For seed, I’m using a tall fescue variety.  I found that putting a very thin layer of compost/soil on top of the seed is the key to having it germinate.

For Fall cleanup, I’m not raking my leaves and simply mulching them into the lawn using the mower.  This gives me “free compost” which I help builds the strength of the lawn.

For watering, I’m changing my schedule so that I do one deep water once a week.  I was watering every other day for 10-15 minutes, but that actually encourages weed growth.  A deep soaking forces the grass to dig deeper roots rather than bathing shallow weeds.

For weed control, I mix up 1 gallon of white vinegar, 1 cup of salt and a 2 tablespoons of dish soap.  I walk around the yard spraying this on any dandelions.  It works really well as long as you keep up with it.  Be sure to spray it on a dry day so it has a chance to dry onto the weed.

For seed patching in the Spring, I star with a 5 gallon bucket.  I mix 1/3 top soil, 1/3 peat moss, 1/3 compost/manure, 2 cups of grass seeds and some organic fertilizer.  Mix that very well and having two buckets to transfer/mix helps.  You should have about 20 seeds per square inch (approximate by taking and counting in the palm of your hand).  Apply to dead areas by raking the bar spot to expose the soil (no thatch, leaves, etc should be present).  Apply a 1/4 inch layer of your seed patch mix on top.  Stamp down with your foot and water daily for at least a week.  I like to do this right before I see a rainy week of weather.

Quick Pickle

Quick Pickle

Quick Pickle

Quick Pickle


  • 3 cups water
  • 1 cup sugar
  • 1 cup vinegar
  • peppercorns
  • mustard seeds
  • crushed red pepper
  • cloves
  • turmeric
  • dried chili
  • 1 1/2 tablespoons kosher salt


  1. Cut up your favorite pickling vegetables. I like to do layers of sliced carrots, onion, celery and cucumber. Put in two mason jars.
  2. Combine all pickling ingredients in a pot and bring to a boil.
  3. Carefully pour into mason jars, cover and put in fridge when cool enough to handle.

Node NodeJS with Lamp on Apache Bitnami Stack

I wanted to test some of the new Facebook Messenger bots and since “The Facebook” requests your services to have https, I wanted to leverage my existing domain that already has ssl setup.  Unfortunately when you pick a Lightsail instance, it’s Node.JS or LAMP.  Since I already had a LAMP instance, my goal was just to have Node running on top.

I was a little hesitant because I didn’t want to have Node conflict with Apache and take down my existing site.  What I learned is that NodeJS (or Node which are the same thing) won’t conflict as you can run your service on another port.  However, there is some setup that you need to take care of.  If you are nervous about messing up an existing instance, just spin up a new light sail instance which is similar to your existing and play around with the package installs on that one.

Install NodeJs

Assuming you already have a Lightsail Bitnami LAMP instance (or similar), you need to install two things:  NodeJS and NPM.  Basically NodeJS is the engine that will run your code and NPM is a package manager.  I was confused on how to get Node and NodeJS both installed not realizing they are the same thing.  The commands to do it are:

sudo apt-get install nodejs
sudo ln -s /usr/bin/nodejs /usr/sbin/node

The 2nd line is to create an alias so that node and nodejs do the same thing

Then install the packages that support the nodejs code

sudo apt-get install npm
npm install

Make sure you run the second line otherwise you downloaded all the packages, but didn’t actually install.

Test you have it working by typing `nodejs –v` and it should tell you the version you have running.

Do a hello world type test now and save these two lines in a script called helloWorld.js

var sys = require("sys");
sys.puts("Hello World");

Now type nodejs helloWorld.js and it should simply say Hello World

Apache Configuration

Next you need to modify your Apache configuration so it knows to pass requests for Node.  For this, you need to know what port your application will run on.  For my setup, I used port 8080.

Open up your /home/bitnami/stack/apache2/conf/bitnami/bitnami.conf file and add these lines to the section of your config that is for port 443

SSLProxyEngine on
SSLProxyVerify none
SSLProxyCheckPeerCN off
SSLProxyCheckPeerName off
SSLProxyCheckPeerExpire off
ProxyRequests Off
ProxyPreserveHost On

<Location /webhook >
   ProxyPass http://localhost:8080/webhook Keepalive=On
   ProxyPassReverse http://localhost:8080/webhook

The key is the Location section above.  This tells apache that for any request that starts with /webhook to pass the request to what you had configured as the url.

Restart Apache for these settings to be applied.  When it restarts, if you did something wrong, it will show you the error.

To be honest, I’m not sure if all those SSLProxy* config settings are necessary, but that’s how it is working in my environment.

Testing Running  A Server

You should have to make one more Lightsail config, but lets setup a test server to start.

Copy and pasta this into a new file and save it as server.js

var sys = require("sys"),
my_http = require("http");
sys.puts("I got kicked");
response.writeHeader(200, {"Content-Type": "text/plain"});
response.write("Hello World");
sys.puts("Server Running on 8080");

Now start it by running nodejs server.js and it should say “Server Running on 8080”

From another terminal session, on the same server, telnet localhost 8080 and it should connect.  Now try doing it from somewhere externally by typing in the URL of your server and what you configured in the apache config.  For instance,   Remember to use https and not to include the port number as that’s already setup in the config.  If that does not work, then you need to open up port 8080,  Go to your LIghtsail instance, click on Manage, Open a CUSTOM port 8080 and save.  Try it again and it should work.  Another way you can test, which will not be be https is to use  They should do the same thing, except not be encrypted.

Run Node as a Service

Once you ctrl-c out of your terminal session, your NodeJS service will stop.  To keep it running in the background install forever.

sudo npm install -g forever

To start it as a service, simply use this command:

forever -o output.log -e error.log start app.js

This will start the service in the background but also put the output into the log files so you can monitor the interactions. To see if it’s running, just run forever list

Facebook Configuration

The entire point of me doing this was to actually test a Facebook Messenger Bot.  I downloaded the sample code from I had a few issues in getting it to work so here are some hints:

Obviously, update the app.js file to reflect the port you are running the service on.  Search for port 5000 which is what the sample code uses and replace it with port 8080.

Your page access token will sometimes change.  If you are getting this error message Failed calling Send API 400 undefined { message: ‘(#100) No matching user found’, then copy and paste it again in your config/default.json file

Your appSecret is from your developer page, click on the app you setup to test and click “Reveal App Secret”.

If Facebook is kicking back errors from your webhook, you can tail your access and error logs to see what they are sending.  You should see a request like this which you can use to manually debug: /webhook?hub.mode=subscribe&hub.challenge=123343443243243&hub.verify_token=your_test_token_that_you_created

My application would error on start due strict mode.  I had to comment out the line (still need to figure out why).

Also, if your proxy is still not working, try adding this line:  app.enable(‘trust proxy’);

Lastly you can start the code by typing npm start in the directory where app.js is located or do nodejs app.js  I initially didn’t understand the “npm start” command until I realized it simply starts whatever it find in current path.

Hopefully that helps.  Another great tutorial similar to the Facebook one can be found here: