forked from kubernetes-csi/csi-driver-iscsi
-
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.
Merge pull request kubernetes-csi#1 from j-griffith/initial_code_add
Initial commit
- Loading branch information
Showing
7 changed files
with
891 additions
and
11 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 |
---|---|---|
@@ -0,0 +1,3 @@ | ||
*.out | ||
_output | ||
example/example |
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,15 @@ | ||
.PHONY: all build clean install | ||
|
||
all: clean build install | ||
|
||
clean: | ||
go clean -r -x | ||
-rm -rf _output | ||
|
||
build: | ||
go build ./iscsi/ | ||
go build -o _output/example ./example/main.go | ||
|
||
install: | ||
go install ./iscsi/ | ||
|
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
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,75 @@ | ||
package main | ||
|
||
import ( | ||
"flag" | ||
"log" | ||
"os" | ||
"strings" | ||
"time" | ||
|
||
"github.com/kubernetes-csi/csi-lib-iscsi/iscsi" | ||
) | ||
|
||
var ( | ||
portals = flag.String("portals", "192.168.1.112:3260", "Comma delimited. Eg: 1.1.1.1,2.2.2.2") | ||
iqn = flag.String("iqn", "iqn.2010-10.org.openstack:volume-95739000-1557-44f8-9f40-e9d29fe6ec47", "") | ||
multipath = flag.Bool("multipath", false, "") | ||
username = flag.String("username", "3aX7EEf3CEgvESQG75qh", "") | ||
password = flag.String("password", "eJBDC7Bt7WE3XFDq", "") | ||
lun = flag.Int("lun", 1, "") | ||
debug = flag.Bool("debug", false, "enable logging") | ||
) | ||
|
||
func main() { | ||
flag.Parse() | ||
tgtp := strings.Split(*portals, ",") | ||
if *debug { | ||
iscsi.EnableDebugLogging(os.Stdout) | ||
} | ||
|
||
// You can utilize the iscsiadm calls directly if you wish, but by creating a Connector | ||
// you can simplify interactions to simple calls like "Connect" and "Disconnect" | ||
c := iscsi.Connector{ | ||
// Our example uses chap | ||
AuthType: "chap", | ||
// Specify the target iqn we're dealing with | ||
TargetIqn: *iqn, | ||
// List of portals must be >= 1 (>1 signals multipath/mpio) | ||
TargetPortals: tgtp, | ||
// CHAP can be setup up for discovery as well as sessions, our example | ||
// device only uses CHAP security for sessions, for those that use Discovery | ||
// as well, we'd add a DiscoverySecrets entry the same way | ||
SessionSecrets: iscsi.Secrets{ | ||
UserName: *username, | ||
Password: *password, | ||
SecretsType: "chap"}, | ||
// Lun is the lun number the devices uses for exports | ||
Lun: int32(*lun), | ||
// Multipath indicates that we want to configure this connection as a multipath device | ||
Multipath: *multipath, | ||
// Number of times we check for device path, waiting for CheckInterval seconds inbetween each check (defaults to 10 if omitted) | ||
RetryCount: 11, | ||
// CheckInterval is the time in seconds to wait inbetween device path checks when logging in to a target | ||
CheckInterval: 1, | ||
} | ||
|
||
// Now we can just issue a connection request using our Connector | ||
// A succesful connection will include the device path to access our iscsi volume | ||
path, err := iscsi.Connect(c) | ||
if err != nil { | ||
log.Printf("Error returned from iscsi.Connect: %s", err.Error()) | ||
os.Exit(1) | ||
} | ||
|
||
if path == "" { | ||
log.Printf("Failed to connect, didn't receive a path, but also no error!") | ||
os.Exit(1) | ||
} | ||
|
||
log.Printf("Connected device at path: %s\n", path) | ||
time.Sleep(3 * time.Second) | ||
|
||
// Disconnect is easy as well, we don't need the full Connector any more, just the Target IQN and the Portals | ||
/// this should disconnect the volume as well as clear out the iscsi DB entries associated with it | ||
iscsi.Disconnect(c.TargetIqn, c.TargetPortals) | ||
} |
Oops, something went wrong.