-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Added cf commands to create service and key
- Added helper setenv.sh script - Updated README.md
- Loading branch information
ladyVader
committed
Jan 17, 2020
1 parent
17449b2
commit 8f11d09
Showing
4 changed files
with
173 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,7 +9,6 @@ build/ | |
build-eclipse/ | ||
/tags | ||
out/ | ||
setenv.sh | ||
|
||
.DS_store | ||
*.iml | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -11,7 +11,10 @@ It uses: | |
- GemFire 9.8.4 | ||
|
||
## Deploy Application | ||
### PCFOne | ||
### Create the PCF Environment via PCFOne Ignition (in Okta) OR a pooled (short-lived) or | ||
### custom (long-running) environment using the instructions located here: | ||
### https://docs.google.com/document/d/1zy0w0iiEAWtBvNpGGrbuQ8NqgJJT4GJxnJ07WDr5YD4/edit# | ||
|
||
#### Build Application | ||
Build the application jar using **gradlew** like: | ||
|
||
|
@@ -33,6 +36,11 @@ See https://docs.gradle.org/6.0.1/userguide/command_line_interface.html#sec:comm | |
BUILD SUCCESSFUL in 8s | ||
13 actionable tasks: 13 executed | ||
``` | ||
|
||
## Create space, service-instance and service-instance-key | ||
## configure the servers and deploy necessary jars | ||
server/cmds.txt | ||
|
||
#### Push Client Application | ||
Push the client application using **cf push** like: | ||
|
||
|
@@ -129,13 +137,13 @@ start command: JAVA_OPTS="-agentpath:$PWD/.java-buildpack/open_jdk_jre/bin/jvm | |
Push the CQ client application using **cf push** like: | ||
|
||
``` | ||
cf push -f client_cq/manifest.yml | ||
cf push -f client-cq/manifest.yml | ||
Pushing from manifest to org pivot-boglesby / space playground as [email protected]... | ||
Using manifest file client_cq/manifest.yml | ||
Using manifest file client-cq/manifest.yml | ||
Getting app info... | ||
Updating app with these attributes... | ||
name: clientCqApp | ||
path: /Users/boglesby/Dev/Tests/spring-boot/pcc-long-running-test/client_cq/build/libs/client_cq-0.0.1-SNAPSHOT.jar | ||
path: /Users/boglesby/Dev/Tests/spring-boot/pcc-long-running-test/client-cq/build/libs/client-cq-0.0.1-SNAPSHOT.jar | ||
buildpacks: | ||
https://github.com/cloudfoundry/java-buildpack.git | ||
command: JAVA_OPTS="-agentpath:$PWD/.java-buildpack/open_jdk_jre/bin/jvmkill-1.16.0_RELEASE=printHeapHistogram=1 -Djava.io.tmpdir=$TMPDIR -XX:ActiveProcessorCount=$(nproc) -Djava.ext.dirs=$PWD/.java-buildpack/container_security_provider:$PWD/.java-buildpack/open_jdk_jre/lib/ext -Djava.security.properties=$PWD/.java-buildpack/java_security/java.security $JAVA_OPTS" && CALCULATED_MEMORY=$($PWD/.java-buildpack/open_jdk_jre/bin/java-buildpack-memory-calculator-3.13.0_RELEASE -totMemory=$MEMORY_LIMIT -loadedClasses=23790 -poolType=metaspace -stackThreads=250 -vmOptions="$JAVA_OPTS") && echo JVM Memory Configuration: $CALCULATED_MEMORY && JAVA_OPTS="$JAVA_OPTS $CALCULATED_MEMORY" && MALLOC_ARENA_MAX=2 SERVER_PORT=$PORT eval exec $PWD/.java-buildpack/open_jdk_jre/bin/java $JAVA_OPTS -cp $PWD/. org.springframework.boot.loader.JarLauncher | ||
|
@@ -258,10 +266,22 @@ Retrieving logs for app sdgApp in org pivot-boglesby / space playground as bogle | |
### PCFOne | ||
#### REST | ||
##### Put Command | ||
Run the put command using **curl** like: | ||
Run the put command using **curl** like (modify to match your app urls). | ||
Note that the -k is used to avoid SSL/TLS certificate issues. | ||
|
||
You can get the urls from the output of the cf apps command: | ||
``` | ||
$ cf apps | ||
Getting apps in org system / space mySpace as admin... | ||
OK | ||
name requested state instances memory disk urls | ||
sdgApp started 1/1 768M 1G sdgapp.apps.seoul.cf-app.com | ||
clientCqApp started 1/1 768M 1G clientcqapp.apps.seoul.cf-app.com | ||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/put/10/1024 | ||
|
||
``` | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/put/10/1024 | ||
{"operation":"put","status":"SUCCESS","completionTime":191} | ||
``` | ||
The application will log messages like: | ||
|
@@ -284,7 +304,7 @@ The application will log messages like: | |
Run the get command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/get/10 | ||
curl -k https://sdgapp.apps.pcfone.io/trades/get/10 | ||
{"operation":"get","status":"SUCCESS","completionTime":55} | ||
``` | ||
The application will log messages like: | ||
|
@@ -307,7 +327,7 @@ The application will log messages like: | |
Run the destroy command using **curl** like: | ||
|
||
``` | ||
curl -X DELETE https://sdgapp.apps.pcfone.io/trades/destroy/10 | ||
curl -k -X DELETE https://sdgapp.apps.pcfone.io/trades/destroy/10 | ||
{"operation":"destroy","status":"SUCCESS","completionTime":63} | ||
``` | ||
The application will log messages like: | ||
|
@@ -330,7 +350,7 @@ The application will log messages like: | |
Run the query by cusip command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/querybycusip/10 | ||
curl -k https://sdgapp.apps.pcfone.io/trades/querybycusip/10 | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -352,7 +372,7 @@ The application will log messages like: | |
Run the function update command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/functionupdate/10 | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/functionupdate/10 | ||
{"operation":"functionupdate","status":"SUCCESS","completionTime":65} | ||
``` | ||
The application will log messages like: | ||
|
@@ -375,73 +395,79 @@ The application will log messages like: | |
Run the function update command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/putforever/10/1024 | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/putforever/10/1024 | ||
``` | ||
The application will log messages like: | ||
|
||
``` | ||
{"operation":"putforever","status":"SUCCESS","completionTime":0} | ||
... | ||
``` | ||
##### Get Forever Command | ||
Run the function update command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/getforever/10 | ||
curl -k https://sdgapp.apps.pcfone.io/trades/getforever/10 | ||
``` | ||
The application will log messages like: | ||
|
||
``` | ||
{"operation":"getforever","status":"SUCCESS","completionTime":0} | ||
... | ||
``` | ||
##### Destroy Forever Command | ||
Run the function update command using **curl** like: | ||
|
||
``` | ||
curl -X DELETE https://sdgapp.apps.pcfone.io/trades/destroyforever/10 | ||
curl -k -X DELETE https://sdgapp.apps.pcfone.io/trades/destroyforever/10 | ||
``` | ||
The application will log messages like: | ||
|
||
``` | ||
{"operation":"destroyforever","status":"SUCCESS","completionTime":0} | ||
... | ||
``` | ||
##### Query by Cusip Forever Command | ||
Run the function update command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/querybycusipforever | ||
curl -k https://sdgapp.apps.pcfone.io/trades/querybycusipforever | ||
``` | ||
The application will log messages like: | ||
|
||
``` | ||
{"operation":"querybycusipforever","status":"SUCCESS","completionTime":0} | ||
... | ||
``` | ||
##### Function Update Forever Command | ||
Run the function update command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/functionupdateforever/10 | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/functionupdateforever/10 | ||
``` | ||
The application will log messages like: | ||
|
||
``` | ||
{"operation":"functionupdateforever","status":"SUCCESS","completionTime":0} | ||
... | ||
``` | ||
##### Multi-threaded Put Forever Command | ||
Run the multi-threaded put forever command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/putforever/10/1024/5 | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/putforever/10/1024/5 | ||
``` | ||
The application will log messages like: | ||
|
||
``` | ||
{"operation":"putforever","status":"SUCCESS","completionTime":0} | ||
... | ||
``` | ||
##### Multi-threaded Get Forever Command | ||
Run the multi-threaded get forever command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/getforever/10/5 | ||
curl -k https://sdgapp.apps.pcfone.io/trades/getforever/10/5 | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -452,7 +478,7 @@ The application will log messages like: | |
Run the multi-threaded destroy forever command using **curl** like: | ||
|
||
``` | ||
curl -X DELETE https://sdgapp.apps.pcfone.io/trades/destroyforever/10/5 | ||
curl -k -X DELETE https://sdgapp.apps.pcfone.io/trades/destroyforever/10/5 | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -463,7 +489,7 @@ The application will log messages like: | |
Run the multi-threaded query by cusip forever command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/querybycusipforever/5 | ||
curl -k https://sdgapp.apps.pcfone.io/trades/querybycusipforever/5 | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -474,7 +500,7 @@ The application will log messages like: | |
Run the multi-threaded function update command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/functionupdateforever/10/5 | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/functionupdateforever/10/5 | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -485,7 +511,7 @@ The application will log messages like: | |
Run the get one command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/getone/0 | ||
curl -k https://sdgapp.apps.pcfone.io/trades/getone/0 | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -495,7 +521,7 @@ The application will log messages like: | |
Run the query one by cusip command using **curl** like: | ||
|
||
``` | ||
curl https://sdgapp.apps.pcfone.io/trades/queryonebycusip/AAPL | ||
curl -k https://sdgapp.apps.pcfone.io/trades/queryonebycusip/AAPL | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -505,7 +531,7 @@ The application will log messages like: | |
Run the test command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/starttest/100000/1024 | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/starttest/100000/1024 | ||
[{"operation":"putforever","status":"SUCCESS","completionTime":0},{"operation":"getforever","status":"SUCCESS","completionTime":0},{"operation":"querybycusipforever","status":"SUCCESS","completionTime":0},{"operation":"functionupdateforever","status":"SUCCESS","completionTime":0}] | ||
``` | ||
The application will log messages like: | ||
|
@@ -533,7 +559,7 @@ The application will log messages like: | |
Run the stop operations command using **curl** like: | ||
|
||
``` | ||
curl -X POST https://sdgapp.apps.pcfone.io/trades/stopoperations | ||
curl -k -X POST https://sdgapp.apps.pcfone.io/trades/stopoperations | ||
``` | ||
The application will log messages like: | ||
|
||
|
@@ -1406,4 +1432,7 @@ The application will log messages like: | |
2019-12-19 15:51:19.022 INFO 58371 --- [ Thread-13] i.p.test.client.service.TradeService : Stopping after updating 63754 trades with function | ||
2019-12-19 15:51:19.022 INFO 58371 --- [ Thread-6] i.p.test.client.service.TradeService : Stopping after putting 74523 trades of size 1024 bytes | ||
``` | ||
|
||
|
||
### Accessing AppsMgr from Long-Running Custom PCF Environment: | ||
url: app.sys.seoul.cf-app.com (appsMgr) | ||
Use admin username + password from PAS > Credentials > UAA > Admin Credentials |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
// Create your PCF Deployment via PCFOne or according to this document for a cf toolsmith pooled or customer pcf environment | ||
https://docs.google.com/document/d/1zy0w0iiEAWtBvNpGGrbuQ8NqgJJT4GJxnJ07WDr5YD4/edit# | ||
|
||
// login to your PCF deployment (for this example, seoul) | ||
$ cf login --skip-ssl-validation -a https://api.sys.seoul.cf-app.com | ||
|
||
// prompted for Email (simply admin) + Password from PAS Tile > Credentials Tab => UAA Admin Credentials | ||
Email> admin | ||
Password> WsTijPw3_AD53PtcrlQd1ar-oKxeTrTC | ||
|
||
// create and login to space | ||
$ cf create-space SPACE-NAME | ||
$ cf create-space mySpace | ||
|
||
$ cf target -s SPACE-NAME | ||
$ cf target -s mySpace | ||
|
||
// Create the PCC service instance (your GemFire cluster): | ||
// The PLAN-NAME is one of the plans from your configured PCC tile. You can list your available plans on the command line with: | ||
$ cf marketplace -s p-cloudcache | ||
|
||
// output from marketplace command | ||
service plan description free or paid | ||
dev-plan Plan Description free | ||
small-footprint Plan Description free | ||
|
||
$ cf create-service SERVICE-NAME PLAN-NAME SERVICE-INSTANCE-NAME | ||
$ cf create-service p-cloudcache dev-plan pccService | ||
or | ||
$ cf create-service p-cloudcache small-footprint pccService | ||
|
||
// You can check on the progress of the create with | ||
$ cf service SERVICE-INSTANCE-NAME | ||
$ cf service pccService | ||
|
||
// Create service-key | ||
$ cf create-service-key SERVICE_INSTANCE SERVICE_KEY | ||
$ cf create-service-key pccService pccServiceKey | ||
|
||
// To find any existing key | ||
$ cf service-keys SERVICE-INSTANCE-NAME | ||
$ cf service-keys pccService | ||
|
||
// output shows our service key (helpful if you are coming back to your deployment) | ||
pccServiceKey | ||
|
||
// get gfsh connect cmd and other details from cf env | ||
$ cf service-key pccService pccServiceKey | ||
|
||
// output from cf service-key command | ||
{ | ||
"distributed_system_id": "0", | ||
"gfsh_login_string": "connect --url=https://cloudcache-740fbd64-f250-45d2-8162-e73ce0a4c825.sys.seoul.cf-app.com/gemfire/v1 --user=cluster_operator_83ZGNx2UW0QfjSVOrW9w --password=iqiN05MzAaO52WtiMlHcQw --skip-ssl-validation", | ||
"locators": [ | ||
"20cd56e5-c1fe-4f6e-8f6a-354ff2516f03.locator-server.seoul-services-subnet.service-instance-740fbd64-f250-45d2-8162-e73ce0a4c825.bosh[55221]" | ||
], | ||
"remote_cluster_info": { | ||
"recursors": { | ||
"seoul-services-subnet.service-instance-740fbd64-f250-45d2-8162-e73ce0a4c825.bosh": [ | ||
"10.0.8.5:1053" | ||
] | ||
}, | ||
"remote_locators": [ | ||
"20cd56e5-c1fe-4f6e-8f6a-354ff2516f03.locator-server.seoul-services-subnet.service-instance-740fbd64-f250-45d2-8162-e73ce0a4c825.bosh[55221]" | ||
], | ||
"trusted_sender_credentials": [ | ||
{ | ||
"password": "OUUJDi3eYfqEIMxfRldQ", | ||
"username": "gateway_sender_9meHmbnMFvGDVKYRtAbpA" | ||
} | ||
] | ||
}, | ||
"urls": { | ||
"gfsh": "https://cloudcache-740fbd64-f250-45d2-8162-e73ce0a4c825.sys.seoul.cf-app.com/gemfire/v1", | ||
"management": "https://cloudcache-740fbd64-f250-45d2-8162-e73ce0a4c825.sys.seoul.cf-app.com/management/docs", | ||
"management.experimental": "https://cloudcache-740fbd64-f250-45d2-8162-e73ce0a4c825.sys.seoul.cf-app.com/management/experimental", | ||
"pulse": "https://cloudcache-740fbd64-f250-45d2-8162-e73ce0a4c825.sys.seoul.cf-app.com/pulse" | ||
}, | ||
"users": [ | ||
{ | ||
"password": "iqiN05MzAaO52WtiMlHcQw", | ||
"roles": [ | ||
"cluster_operator" | ||
], | ||
"username": "cluster_operator_83ZGNx2UW0QfjSVOrW9w" | ||
}, | ||
{ | ||
"password": "Sf37QgrP1ISjy3yT5kOv1A", | ||
"roles": [ | ||
"developer" | ||
], | ||
"username": "developer_bvLag6gQ9ThXk5MxK7YJw" | ||
}, | ||
{ | ||
"password": "KeStZRpRwm0LtBqTecC0og", | ||
"roles": [ | ||
"readonly" | ||
], | ||
"username": "readonly_oYZFhTn83VHIq6gmORXGPg" | ||
} | ||
], | ||
"wan": {} | ||
} | ||
|
||
## Execute the bin/configure.sh script to deploy functions, create regions and indexes | ||
## You may need to modify the path for gfsh (to use the correct version of gfsh for your | ||
## deployment). | ||
./bin/configure.sh | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
#! /bin/bash | ||
|
||
# setup env vars for testing gemfire | ||
export URL=https://cloudcache-de0ec798-387a-46cf-9204-43310457fa32.sys.seoul.cf-app.com/gemfire/v1 | ||
export USERNAME=cluster_operator_edyVeKCT8jm6TIuARUzg | ||
export PASSWORD=C2ckGND20OD7txfGlcMZXw | ||
|
||
# my gfsh connect command | ||
#connect --url=https://cloudcache-de0ec798-387a-46cf-9204-43310457fa32.sys.seoul.cf-app.com/gemfire/v1 --user=cluster_operator_edyVeKCT8jm6TIuARUzg --password=C2ckGND20OD7txfGlcMZXw --skip-ssl-validation |