Merge pull request #702 from harshavardhana/pr_out_add_disk_detection_for_linux_add_new_rpc_service_getdiskinfoservice_remove_dummy_helloservice_
commit
486b82e950
@ -0,0 +1,58 @@ |
||||
/* |
||||
* Minimalist Object Storage, (C) 2015 Minio, Inc. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package rpc |
||||
|
||||
import ( |
||||
"net/http" |
||||
"os" |
||||
|
||||
"github.com/minio/minio/pkg/iodine" |
||||
"github.com/minio/minio/pkg/utils/scsi" |
||||
) |
||||
|
||||
// GetDiskInfoService disk info service
|
||||
type GetDiskInfoService struct{} |
||||
|
||||
// GetDiskInfoReply disk info reply for disk info service
|
||||
type GetDiskInfoReply struct { |
||||
Hostname string `json:"hostname"` |
||||
Disks []string `json:"disks"` |
||||
DiskAttributes map[string]scsi.Attributes `json:"disk-attrs"` |
||||
} |
||||
|
||||
func setDiskInfoReply(sis *GetDiskInfoReply) error { |
||||
var err error |
||||
sis.Hostname, err = os.Hostname() |
||||
if err != nil { |
||||
return iodine.New(err, nil) |
||||
} |
||||
disks, err := scsi.GetDisks() |
||||
if err != nil { |
||||
return iodine.New(err, nil) |
||||
} |
||||
sis.DiskAttributes = make(map[string]scsi.Attributes) |
||||
for k, v := range disks { |
||||
sis.Disks = append(sis.Disks, k) |
||||
sis.DiskAttributes[k] = v |
||||
} |
||||
return nil |
||||
} |
||||
|
||||
// Get method
|
||||
func (s *GetDiskInfoService) Get(r *http.Request, args *Args, reply *GetDiskInfoReply) error { |
||||
return setDiskInfoReply(reply) |
||||
} |
@ -0,0 +1,55 @@ |
||||
/* |
||||
* Minimalist Object Storage, (C) 2015 Minio, Inc. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package rpc |
||||
|
||||
import ( |
||||
"net/http" |
||||
"time" |
||||
) |
||||
|
||||
// Args basic json RPC params
|
||||
type Args struct { |
||||
Request string |
||||
} |
||||
|
||||
// VersionReply version reply
|
||||
type VersionReply struct { |
||||
Version string `json:"version"` |
||||
BuildDate string `json:"build-date"` |
||||
} |
||||
|
||||
// VersionService -
|
||||
type VersionService struct{} |
||||
|
||||
func getVersion() string { |
||||
return "0.0.1" |
||||
} |
||||
func getBuildDate() string { |
||||
return time.Now().UTC().Format(http.TimeFormat) |
||||
} |
||||
|
||||
func setVersionReply(reply *VersionReply) { |
||||
reply.Version = getVersion() |
||||
reply.BuildDate = getBuildDate() |
||||
return |
||||
} |
||||
|
||||
// Get method
|
||||
func (v *VersionService) Get(r *http.Request, args *Args, reply *VersionReply) error { |
||||
setVersionReply(reply) |
||||
return nil |
||||
} |
@ -0,0 +1,66 @@ |
||||
// +build linux,amd64
|
||||
|
||||
/* |
||||
* Mini Object Storage, (C) 2014 Minio, Inc. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package scsi |
||||
|
||||
// System sysfs constants
|
||||
const ( |
||||
// From 2.6.x kernel onwards, no need to support procfs
|
||||
sysFSROOT = "/sys" |
||||
sysFSDEVICES = "/sys/bus/scsi/devices" |
||||
sysFSBLOCK = "/block" |
||||
sysFSCLASSSCSIDEVICES = "/sys/class/scsi_device" |
||||
udev = "/dev" |
||||
devDISKBYID = "/dev/disk/by-id" |
||||
) |
||||
|
||||
// ScsiDEVICETYPES list of various scsi devices
|
||||
var ScsiDEVICETYPES = []string{ |
||||
"disk", |
||||
"tape", |
||||
"printer", |
||||
"process", |
||||
"worm", |
||||
"cd/dvd", |
||||
"scanner", |
||||
"optical", |
||||
"mediumx", |
||||
"comms", |
||||
"(0xa)", |
||||
"(0xb)", |
||||
"storage", |
||||
"enclosu", |
||||
"sim disk", |
||||
"optical rd", |
||||
"bridge", |
||||
"osd", |
||||
"adi", |
||||
"sec man", |
||||
"zbc", |
||||
"(0x15)", |
||||
"(0x16)", |
||||
"(0x17)", |
||||
"(0x18)", |
||||
"(0x19)", |
||||
"(0x1a)", |
||||
"(0x1b)", |
||||
"(0x1c)", |
||||
"(0x1e)", |
||||
"wlun", |
||||
"no dev", |
||||
} |
@ -0,0 +1,48 @@ |
||||
// +build linux,amd64
|
||||
|
||||
/* |
||||
* Mini Object Storage, (C) 2014 Minio, Inc. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package scsi |
||||
|
||||
import ( |
||||
"io/ioutil" |
||||
"os" |
||||
"path" |
||||
"strings" |
||||
) |
||||
|
||||
func getattrs(scsiAttrPath string, scsiAttrList []string) map[string]string { |
||||
attrMap := make(map[string]string) |
||||
for _, attr := range scsiAttrList { |
||||
value, _ := ioutil.ReadFile(path.Join(scsiAttrPath, attr)) |
||||
attrMap[attr] = strings.Trim(string(value[:]), "\n") // remove odd newlines
|
||||
} |
||||
return attrMap |
||||
} |
||||
|
||||
func filterdisks(files []os.FileInfo) (scsidisks []string) { |
||||
for _, fi := range files { |
||||
if strings.Contains(fi.Name(), "host") { |
||||
continue |
||||
} |
||||
if strings.Contains(fi.Name(), "target") { |
||||
continue |
||||
} |
||||
scsidisks = append(scsidisks, fi.Name()) |
||||
} |
||||
return scsidisks |
||||
} |
@ -0,0 +1,101 @@ |
||||
// +build linux,amd64
|
||||
|
||||
/* |
||||
* Minimalist Object Storage, (C) 2015 Minio, Inc. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package scsi |
||||
|
||||
import ( |
||||
"errors" |
||||
"io/ioutil" |
||||
"path/filepath" |
||||
|
||||
"github.com/minio/minio/pkg/iodine" |
||||
) |
||||
|
||||
// NOTE : supporting virtio based scsi devices is out of scope for this implementation
|
||||
|
||||
// Attributes Scsi device attributes
|
||||
type Attributes map[string]string |
||||
|
||||
// Disks is a list of scsis disks and attributes
|
||||
type Disks map[string]Attributes |
||||
|
||||
// Get get disk scsi params
|
||||
func (d Disks) Get(disk string) Attributes { |
||||
return d[disk] |
||||
} |
||||
|
||||
// Len return len of total disks
|
||||
func (d Disks) Len() int { |
||||
return len(d) |
||||
} |
||||
|
||||
// GetDisks - get system devices list
|
||||
func GetDisks() (Disks, error) { |
||||
var scsidevices []string |
||||
var scsiAttrList []string |
||||
d := Disks{} |
||||
|
||||
sysFiles, err := ioutil.ReadDir(sysFSDEVICES) |
||||
if err != nil { |
||||
return Disks{}, iodine.New(err, nil) |
||||
} |
||||
|
||||
scsidevices = filterdisks(sysFiles) |
||||
if len(scsidevices) == 0 { |
||||
// may be a docker instance, ignore this
|
||||
return Disks{}, nil |
||||
} |
||||
|
||||
for _, s := range scsidevices { |
||||
scsiAttrPath := filepath.Join(sysFSDEVICES, s) |
||||
scsiAttrs, err := ioutil.ReadDir(scsiAttrPath) |
||||
if err != nil { |
||||
return Disks{}, iodine.New(err, nil) |
||||
} |
||||
scsiBlockPath := filepath.Join(sysFSDEVICES, s, sysFSBLOCK) |
||||
scsidevList, err := ioutil.ReadDir(scsiBlockPath) |
||||
if err != nil { |
||||
return Disks{}, iodine.New(err, nil) |
||||
} |
||||
if len(scsidevList) > 1 { |
||||
return Disks{}, iodine.New(errors.New("Scsi address points to multiple block devices"), nil) |
||||
} |
||||
device := filepath.Join(udev, scsidevList[0].Name()) |
||||
for _, sa := range scsiAttrs { |
||||
// Skip directories
|
||||
if sa.IsDir() { |
||||
continue |
||||
} |
||||
// Skip symlinks
|
||||
if !sa.Mode().IsRegular() { |
||||
continue |
||||
} |
||||
// Skip, not readable, write-only
|
||||
if sa.Mode().Perm() == 128 { |
||||
continue |
||||
} |
||||
scsiAttrList = append(scsiAttrList, sa.Name()) |
||||
} |
||||
|
||||
if len(scsiAttrList) == 0 { |
||||
return Disks{}, iodine.New(errors.New("No scsi attributes found"), nil) |
||||
} |
||||
d[device] = getattrs(scsiAttrPath, scsiAttrList) |
||||
} |
||||
return d, nil |
||||
} |
@ -0,0 +1,36 @@ |
||||
// +build linux,amd64
|
||||
|
||||
/* |
||||
* Minimalist Object Storage, (C) 2015 Minio, Inc. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package scsi |
||||
|
||||
import ( |
||||
"testing" |
||||
|
||||
. "github.com/minio/check" |
||||
) |
||||
|
||||
type MySuite struct{} |
||||
|
||||
var _ = Suite(&MySuite{}) |
||||
|
||||
func Test(t *testing.T) { TestingT(t) } |
||||
|
||||
func (s *MySuite) TestSCSI(c *C) { |
||||
_, err := GetDisks() |
||||
c.Assert(err, IsNil) |
||||
} |
Loading…
Reference in new issue