mirror of
https://github.com/minio/minio.git
synced 2025-03-20 04:24:19 -04:00
Merge pull request #710 from harshavardhana/pr_out_add_donut_rpc_service_for_sending_changes_to_configuration_files
This commit is contained in:
commit
2c18c3be68
@ -106,7 +106,7 @@ func runController(c *cli.Context) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
Fatalf("Unable to determine current user. Reason: %s\n", err)
|
Fatalf("Unable to determine current user. Reason: %s\n", err)
|
||||||
}
|
}
|
||||||
if len(c.Args()) != 2 || c.Args().First() == "help" {
|
if len(c.Args()) <= 2 || c.Args().First() == "help" {
|
||||||
cli.ShowCommandHelpAndExit(c, "controller", 1) // last argument is exit code
|
cli.ShowCommandHelpAndExit(c, "controller", 1) // last argument is exit code
|
||||||
}
|
}
|
||||||
switch c.Args().First() {
|
switch c.Args().First() {
|
||||||
@ -122,5 +122,11 @@ func runController(c *cli.Context) {
|
|||||||
Fatalln(err)
|
Fatalln(err)
|
||||||
}
|
}
|
||||||
Println(string(memstats))
|
Println(string(memstats))
|
||||||
|
case "donut":
|
||||||
|
hostname, _ := os.Hostname()
|
||||||
|
err := controller.SetDonut(c.Args().Tail().First(), hostname, c.Args().Tail().Tail())
|
||||||
|
if err != nil {
|
||||||
|
Fatalln(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,4 +69,31 @@ func GetMemStats(url string) ([]byte, error) {
|
|||||||
return json.MarshalIndent(reply, "", "\t")
|
return json.MarshalIndent(reply, "", "\t")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SetDonut - set donut config
|
||||||
|
func SetDonut(url, hostname string, disks []string) error {
|
||||||
|
op := RPCOps{
|
||||||
|
Method: "Donut.Set",
|
||||||
|
Request: rpc.DonutArgs{
|
||||||
|
Hostname: hostname,
|
||||||
|
Disks: disks,
|
||||||
|
Name: "default",
|
||||||
|
MaxSize: 512000000,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
req, err := NewRequest(url, op, http.DefaultTransport)
|
||||||
|
if err != nil {
|
||||||
|
return iodine.New(err, nil)
|
||||||
|
}
|
||||||
|
resp, err := req.Do()
|
||||||
|
if err != nil {
|
||||||
|
return iodine.New(err, nil)
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
var reply rpc.Reply
|
||||||
|
if err := jsonrpc.DecodeClientResponse(resp.Body, &reply); err != nil {
|
||||||
|
return iodine.New(err, nil)
|
||||||
|
}
|
||||||
|
return reply.Error
|
||||||
|
}
|
||||||
|
|
||||||
// Add more functions here for many replies
|
// Add more functions here for many replies
|
||||||
|
@ -34,6 +34,7 @@ func getDonutConfigPath() (string, error) {
|
|||||||
return donutConfigPath, nil
|
return donutConfigPath, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NOTE - this is not to be used outside Donut package, this is primarily intended for testing purposes only
|
||||||
var customConfigPath string
|
var customConfigPath string
|
||||||
|
|
||||||
// SaveConfig save donut config
|
// SaveConfig save donut config
|
||||||
|
@ -38,11 +38,6 @@ func New(diskPath string) (Disk, error) {
|
|||||||
if diskPath == "" {
|
if diskPath == "" {
|
||||||
return Disk{}, iodine.New(InvalidArgument{}, nil)
|
return Disk{}, iodine.New(InvalidArgument{}, nil)
|
||||||
}
|
}
|
||||||
s := syscall.Statfs_t{}
|
|
||||||
err := syscall.Statfs(diskPath, &s)
|
|
||||||
if err != nil {
|
|
||||||
return Disk{}, iodine.New(err, nil)
|
|
||||||
}
|
|
||||||
st, err := os.Stat(diskPath)
|
st, err := os.Stat(diskPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return Disk{}, iodine.New(err, nil)
|
return Disk{}, iodine.New(err, nil)
|
||||||
@ -50,6 +45,11 @@ func New(diskPath string) (Disk, error) {
|
|||||||
if !st.IsDir() {
|
if !st.IsDir() {
|
||||||
return Disk{}, iodine.New(syscall.ENOTDIR, nil)
|
return Disk{}, iodine.New(syscall.ENOTDIR, nil)
|
||||||
}
|
}
|
||||||
|
s := syscall.Statfs_t{}
|
||||||
|
err = syscall.Statfs(diskPath, &s)
|
||||||
|
if err != nil {
|
||||||
|
return Disk{}, iodine.New(err, nil)
|
||||||
|
}
|
||||||
disk := Disk{
|
disk := Disk{
|
||||||
path: diskPath,
|
path: diskPath,
|
||||||
fsInfo: make(map[string]string),
|
fsInfo: make(map[string]string),
|
||||||
|
@ -32,7 +32,10 @@ type Minio struct {
|
|||||||
// New instantiate a new minio API
|
// New instantiate a new minio API
|
||||||
func New() Minio {
|
func New() Minio {
|
||||||
// ignore errors for now
|
// ignore errors for now
|
||||||
d, _ := donut.New()
|
d, err := donut.New()
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
return Minio{
|
return Minio{
|
||||||
OP: make(chan Operation),
|
OP: make(chan Operation),
|
||||||
Donut: d,
|
Donut: d,
|
||||||
|
@ -115,6 +115,7 @@ func getRPCHandler() http.Handler {
|
|||||||
s.RegisterService(new(rpc.VersionService), "Version")
|
s.RegisterService(new(rpc.VersionService), "Version")
|
||||||
s.RegisterService(new(rpc.SysInfoService), "SysInfo")
|
s.RegisterService(new(rpc.SysInfoService), "SysInfo")
|
||||||
s.RegisterService(new(rpc.DiskInfoService), "DiskInfo")
|
s.RegisterService(new(rpc.DiskInfoService), "DiskInfo")
|
||||||
|
s.RegisterService(new(rpc.DonutService), "Donut")
|
||||||
// Add new services here
|
// Add new services here
|
||||||
return registerRPC(router.NewRouter(), s)
|
return registerRPC(router.NewRouter(), s)
|
||||||
}
|
}
|
||||||
|
@ -16,16 +16,22 @@
|
|||||||
|
|
||||||
package rpc
|
package rpc
|
||||||
|
|
||||||
import "net/http"
|
import (
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/minio/minio/pkg/donut"
|
||||||
|
"github.com/minio/minio/pkg/iodine"
|
||||||
|
)
|
||||||
|
|
||||||
// DonutService donut service
|
// DonutService donut service
|
||||||
type DonutService struct{}
|
type DonutService struct{}
|
||||||
|
|
||||||
// DonutArgs collections of disks and name to initialize donut
|
// DonutArgs collections of disks and name to initialize donut
|
||||||
type DonutArgs struct {
|
type DonutArgs struct {
|
||||||
MaxSize int64
|
Name string
|
||||||
Name string
|
MaxSize uint64
|
||||||
Disks []string
|
Hostname string
|
||||||
|
Disks []string
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reply reply for successful or failed Set operation
|
// Reply reply for successful or failed Set operation
|
||||||
@ -34,11 +40,21 @@ type Reply struct {
|
|||||||
Error error `json:"error"`
|
Error error `json:"error"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func setDonutArgs(args *DonutArgs, reply *Reply) error {
|
func setDonut(args *DonutArgs, reply *Reply) error {
|
||||||
|
conf := &donut.Config{Version: "0.0.1"}
|
||||||
|
conf.DonutName = args.Name
|
||||||
|
conf.MaxSize = args.MaxSize
|
||||||
|
conf.NodeDiskMap = make(map[string][]string)
|
||||||
|
conf.NodeDiskMap[args.Hostname] = args.Disks
|
||||||
|
if err := donut.SaveConfig(conf); err != nil {
|
||||||
|
return iodine.New(err, nil)
|
||||||
|
}
|
||||||
|
reply.Message = "success"
|
||||||
|
reply.Error = nil
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set method
|
// Set method
|
||||||
func (s *DonutService) Set(r *http.Request, args *DonutArgs, reply *Reply) error {
|
func (s *DonutService) Set(r *http.Request, args *DonutArgs, reply *Reply) error {
|
||||||
return setDonutArgs(args, reply)
|
return setDonut(args, reply)
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user