hbase: New package and NixOS module
This commit is contained in:
		
							parent
							
								
									4c1d65130f
								
							
						
					
					
						commit
						8964667bcd
					
				| @ -165,6 +165,7 @@ | ||||
|       liquidsoap = 155; | ||||
|       etcd = 156; | ||||
|       docker-registry = 157; | ||||
|       hbase = 158; | ||||
| 
 | ||||
|       # When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399! | ||||
| 
 | ||||
| @ -284,6 +285,7 @@ | ||||
|       mlmmj = 135; | ||||
|       riemann = 137; | ||||
|       riemanndash = 138; | ||||
|       hbase = 139; | ||||
|       uhub = 142; | ||||
|       mailpile = 146; | ||||
|       redmine = 147; | ||||
|  | ||||
| @ -108,6 +108,7 @@ | ||||
|   ./services/databases/4store.nix | ||||
|   ./services/databases/couchdb.nix | ||||
|   ./services/databases/firebird.nix | ||||
|   ./services/databases/hbase.nix | ||||
|   ./services/databases/influxdb.nix | ||||
|   ./services/databases/memcached.nix | ||||
|   ./services/databases/monetdb.nix | ||||
|  | ||||
							
								
								
									
										102
									
								
								nixos/modules/services/databases/hbase.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								nixos/modules/services/databases/hbase.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,102 @@ | ||||
| { config, lib, pkgs, ... }: | ||||
| 
 | ||||
| with lib; | ||||
| 
 | ||||
| let | ||||
|   cfg = config.services.hbase; | ||||
| 
 | ||||
| in { | ||||
| 
 | ||||
|   ###### interface | ||||
| 
 | ||||
|   options = { | ||||
| 
 | ||||
|     services.hbase = { | ||||
| 
 | ||||
|       enable = mkOption { | ||||
|         type = types.bool; | ||||
|         default = false; | ||||
|         description = '' | ||||
|           Whether to run HBase. | ||||
|         ''; | ||||
|       }; | ||||
| 
 | ||||
|       package = mkOption { | ||||
|         type = types.package; | ||||
|         default = pkgs.hbase; | ||||
|         example = literalExample "pkgs.hbase"; | ||||
|         description = '' | ||||
|           HBase package to use. | ||||
|         ''; | ||||
|       }; | ||||
| 
 | ||||
| 
 | ||||
|       user = mkOption { | ||||
|         type = types.string; | ||||
|         default = "hbase"; | ||||
|         description = '' | ||||
|           User account under which HBase runs. | ||||
|         ''; | ||||
|       }; | ||||
| 
 | ||||
|       group = mkOption { | ||||
|         type = types.string; | ||||
|         default = "hbase"; | ||||
|         description = '' | ||||
|           Group account under which HBase runs. | ||||
|         ''; | ||||
|       }; | ||||
| 
 | ||||
|       dataDir = mkOption { | ||||
|         type = types.path; | ||||
|         default = "/var/lib/hbase"; | ||||
|         description = '' | ||||
|           Specifies location of HBase database files. This location should be | ||||
|           writable and readable for the user the HBase service runs as | ||||
|           (hbase by default). | ||||
|         ''; | ||||
|       }; | ||||
| 
 | ||||
|       logDir = mkOption { | ||||
|         type = types.path; | ||||
|         default = "/var/log/hbase"; | ||||
|         description = '' | ||||
|           Specifies the location of HBase log files. | ||||
|         ''; | ||||
|       }; | ||||
| 
 | ||||
|     }; | ||||
| 
 | ||||
|   }; | ||||
| 
 | ||||
|   ###### implementation | ||||
| 
 | ||||
|   config = mkIf config.services.hbase.enable { | ||||
| 
 | ||||
|     systemd.services.hbase = { | ||||
|       description = "HBase Server"; | ||||
|       wantedBy = [ "multi-user.target" ]; | ||||
| 
 | ||||
|       environment = { | ||||
|         JAVA_HOME = "${pkgs.jre}"; | ||||
|         HBASE_LOG_DIR = cfg.logDir; | ||||
|       }; | ||||
| 
 | ||||
|       serviceConfig = { | ||||
|         PermissionsStartOnly = true; | ||||
|         User = cfg.user; | ||||
|         Group = cfg.group; | ||||
|         ExecStart = "${cfg.package}/bin/hbase master start"; | ||||
|       }; | ||||
|     }; | ||||
| 
 | ||||
|     users.extraUsers.hbase = { | ||||
|       description = "HBase Server user"; | ||||
|       group = "hbase"; | ||||
|       uid = config.ids.uids.hbase; | ||||
|     }; | ||||
| 
 | ||||
|     users.extraGroups.hbase.gid = config.ids.gids.hbase; | ||||
| 
 | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										13
									
								
								pkgs/servers/hbase/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								pkgs/servers/hbase/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | ||||
| { stdenv, fetchurl, jre, makeWrapper }: | ||||
| stdenv.mkDerivation { | ||||
|   name = "hbase-0.98.8"; | ||||
|   src = fetchurl { | ||||
|     url = http://mirror.gopotato.co.uk/apache/hbase/stable/hbase-0.98.8-hadoop2-bin.tar.gz; | ||||
|     sha256 = "0nvxaqpw8v2hg6mn2p2zxj3y6r4dj4xzxmp8rfmv6m6algn5apv6"; | ||||
|   }; | ||||
|   buildInputs = [ makeWrapper ]; | ||||
|   installPhase = '' | ||||
|     mkdir -p $out | ||||
|     cp -R * $out | ||||
|   ''; | ||||
| } | ||||
| @ -12801,5 +12801,6 @@ let | ||||
|   youtubeDL = youtube-dl;  # added 2014-10-26 | ||||
|   rdiff_backup = rdiff-backup;  # added 2014-11-23 | ||||
| 
 | ||||
|   hbase = callPackage ../servers/hbase {}; | ||||
| 
 | ||||
| }; in self; in pkgs | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Oliver Charles
						Oliver Charles